mybatis 集合、数组类型参数语法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis 集合、数组类型参数语法相关的知识,希望对你有一定的参考价值。

参考技术A https://blog.csdn.net/sinat_28978689/article/details/79406832

解释:

当我们传递一个 List 实例或者数组作为参数对象传给 MyBatis。当你这么做的时 候, MyBatis 会自动将它包装在一个 Map 中,用名称在作为键。List 实例将会以“list” 作为键,而数组实例将会以“array”作为键。 所以,当我们传递的是一个List集合时,mybatis会自动把我们的list集合包装成以list为Key值的map。

DAO层:

Long selectCustomerCountList(@Param("customerIdList") List customerIdList);

XML文件:

<select id="selectCustomerCountList" parameterType="java.util.List" resultType="java.lang.Long">

        select count(1) from np_customer_info where id in

        <foreach item="item" collection="customerIdList" separator="," open="(" close=")" index="">  #item, jdbcType=INTEGER   

        </foreach>

    </select>

======================

注意: 此时的DAO层参数名可以 @Param("customerIdList") 与 collection的属性值一致

https://blog.csdn.net/jaryle/article/details/88531632

Java基础语法

【方法重载】

1.概述:在同一个类中,允许存在一个以上的同名方法,只要它们的参数个数或者参数类型不同即可。

2.特点:与返回值类型无关,只看方法名和参数列表。在调用时,虚拟机通过参数列表的不同来区分同名方法。

 

【数组】

1.概念

数组是存储同一种数据类型多个元素的集合。也可以看成是一个容器。

数组既可以存储基本数据类型,也可以存储引用数据类型。

 

2.数组的定义格式

格式1:数据类型[] 数组名;

格式2:数据类型 数组名[];

注意:这两种定义做完了,数组中是没有元素值的。

 

3.数组初始化概述

Java中的数组必须先初始化,然后才能使用。所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值。

 

4.数组的初始化方式

(1)动态初始化:初始化时只指定数组长度,由系统为数组分配初始值。

格式:

--数据类型[] 数组名 = new 数据类型[数组长度];

--数组长度其实就是数组中元素的个数。

--举例: int[] arr = new int[3];

--解释:定义了一个int类型的数组,这个数组中可以存放3个int类型的值。

 

(2)静态初始化:初始化时指定每个数组元素的初始值,由系统决定数组长度。

格式:

数据类型[] 数组名 = new 数据类型[]{元素1,元素2,…};

举例: int[] arr = new int[]{1,2,3};

解释:定义了一个int类型的数组,这个数组中可以存放3个int类型的值,并且值分别是1,2,3。 其实这种写法还有一个简化的写法 int[] arr = {1,2,3};

 

【Java中的内存分配】

Java 程序在运行时,需要在内存中的分配空间。为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式

--栈:存储局部变量

--堆:存储new出来的东西

--方法区:存储方法

--本地方法区:(和系统相关)

--寄存器:(给CPU使用)

注:(1)在方法定义中或者方法声明上的变量都称为局部变量。 

        (2)堆内存的特点:

                 每一个new出来的东西都有地址值。

                 每个变量都有默认值:

                               byte, short, int, long  --0

                                float, double  --0.0

                                char -- \'\\u0000\'

                                boolean  --false

                                 引用类型 -- null

          (3)使用完毕就会变成垃圾,但是并没有立即回收。会在立即回收器空闲的时候回收。

 

Java中数组的内存图解:

定义一个数组,输出数组名及元素。然后给数组中的元素赋值,再次输出数组名及元素。

 定义两个数组,分别输出数组名及元素。然后分别给数组中的元素赋值,分别再次输出数组名及元素。

 

定义两个数组,先定义一个数组,赋值,输出。然后定义第二个数组的时候把第一个数组的地址赋值给第二个数组。然后给第二个数组赋值,再次输出两个数组的名及元素。

【数组操作常见的两个小问题】

1.数组索引越界

ArrayIndexOutOfBoundsException 访问到了数组中的不存在的索引时发生。

2.空指针异常

NullPointerException 数组引用没有指向实体,却在操作实体中的元素时。

 

【二维数组】

1.概述

其实二维数组其实就是一个元素为一维数组的数组。

 

2.二维数组定义格式

(1)格式1

数据类型[][] 变量名 = new 数据类型[m][n];

-m表示这个二维数组有多少个一维数组

-n表示每一个一维数组的元素个数

举例:

int[][] arr = new int[3][2];

-定义了一个二维数组arr,

-这个二维数组有3个一维数组,名称是arr[0],arr[1],arr[2],

-每个一维数组有2个元素,可以通过arr[m][n]来获取 表示获取第m+1个一维数组的第n+1个元素。

 

 

(2)格式2

数据类型[][] 变量名 = new 数据类型[m][];

-m表示这个二维数组有多少个一维数组

-这一次没有直接给出一维数组的元素个数,可以动态的给出。

举例:

int[][] arr = new int[3][];

arr[0] = new int[2];

arr[1] = new int[3]

arr[2] = new int[1];

 

 

(3)格式3

数据类型[][] 变量名 = new 数据类型[][]{{元素…},{元素…},{元素…}};

简化版格式: 数据类型[][] 变量名 = {{元素…},{元素…},{元素…}};

举例: int[][] arr = {{1,2,3},{4,6},{6}};

 

以上是关于mybatis 集合、数组类型参数语法的主要内容,如果未能解决你的问题,请参考以下文章

mybatis数组和集合的长度判断及插入

Mybatis实现批量删除

Mybatis实现批量删除操作

MyBatis--动态SQL(foreach的用法--实现in集合)

mybatis 传入string参数,parametertype怎样写

mybatis不同参数传递取值方式