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--动态SQL(foreach的用法--实现in集合)