MyBatis传入参数为list、数组、map写法

1.foreach简单介绍:

foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。

foreach元素的属性主要有item,index,collection,open,separator,close。

item表示集合中每一个元素进行迭代时的别名,

index指定一个名字,用于表示在迭代过程中,每次迭代到的位置,

open表示该语句以什么开始,

separator表示在每次进行迭代之间以什么符号作为分隔符,

close表示以什么结束,

collection属性是在使用foreach的时候最关键的也是最容易出错的,该属性是必须指定的,但是在不同情况下,该属性的值是不一样的,主要有一下3种情况: 

(1)如果传入的是单参数且参数类型是一个List的时候,collection属性值为list .

(2)如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array .

(3)如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.

(4)如果传入的是单个参数且参数类型为List的时候,使用@Param()注释参数名字,那么collection属性值为参数名字。例:[2]

Dao:

List<User> findListByIds(@Param("idList")List<String> idList);

XML

<select id="findListByIds" parameterType="java.util.List" resultType="User">select * from t_user where id in<foreach item="item" index="index" collection="idList" open="(" separator="," close=")">#{item}</foreach>
</select>


2.实践-实体类

[java] view plaincopy
  1. public class Employees {  
  2.     private Integer employeeId;  
  3.     private String firstName;  
  4.     private String lastName;  
  5.     private String email;  
  6.     private String phoneNumber;  
  7.     private Date hireDate;  
  8.     private String jobId;  
  9.     private BigDecimal salary;  
  10.     private BigDecimal commissionPct;  
  11.     private Integer managerId;  
  12.     private Short departmentId;  
  13. }    

3.实践-XML

[html] view plaincopy
  1. <!--List:forech中的collection属性类型是List,collection的值必须是:list,item的值可以随意,Dao接口中参数名字随意 -->  
  2.     <select id="getEmployeesListParams" resultType="Employees">  
  3.         select *  
  4.         from EMPLOYEES e  
  5.         where e.EMPLOYEE_ID in  
  6.         <foreach collection="list" item="employeeId" index="index"  
  7.             open="(" close=")" separator=",">  
  8.             #{employeeId}  
  9.         </foreach>  
  10.     </select>  
  11.   
  12.     <!--Array:forech中的collection属性类型是array,collection的值必须是:list,item的值可以随意,Dao接口中参数名字随意 -->  
  13.     <select id="getEmployeesArrayParams" resultType="Employees">  
  14.         select *  
  15.         from EMPLOYEES e  
  16.         where e.EMPLOYEE_ID in  
  17.         <foreach collection="array" item="employeeId" index="index"  
  18.             open="(" close=")" separator=",">  
  19.             #{employeeId}  
  20.         </foreach>  
  21.     </select>  
  22.   
  23.     <!--Map:不单单forech中的collection属性是map.key,其它所有属性都是map.key,比如下面的departmentId -->  
  24.     <select id="getEmployeesMapParams" resultType="Employees">  
  25.         select *  
  26.         from EMPLOYEES e  
  27.         <where>  
  28.             <if test="departmentId!=null and departmentId!=''">  
  29.                 e.DEPARTMENT_ID=#{departmentId}  
  30.             </if>  
  31.             <if test="employeeIdsArray!=null and employeeIdsArray.length!=0">  
  32.                 AND e.EMPLOYEE_ID in  
  33.                 <foreach collection="employeeIdsArray" item="employeeId"  
  34.                     index="index" open="(" close=")" separator=",">  
  35.                     #{employeeId}  
  36.                 </foreach>  
  37.             </if>  
  38.         </where>  
  39.     </select>  

4.实践-Mapper

[java] view plaincopy
  1. public interface EmployeesMapper {   
  2.   
  3.     List<Employees> getEmployeesListParams(List<String> employeeIds);  
  4.   
  5.     List<Employees> getEmployeesArrayParams(String[] employeeIds);  
  6.   
  7.     List<Employees> getEmployeesMapParams(Map<String,Object> params);  
  8. }  

原文出处:
[1] zhangqifeng92, MyBatis传入参数为list、数组、map写法, https://blog.csdn.net/s592652578/article/details/52871884
[2] 实践经验,亲测可用

转载于:https://www.cnblogs.com/ryelqy/p/10104070.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/266891.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言自定义浮点函数,C语言float

C语言float教程C语言float定义详解语法float varname value;参数参数描述float定义 float 类型变量使用的类型。varname变量名。value可选&#xff0c;变量的初始值。说明使用 float 定义了一个 float 类型的变量 varname&#xff0c;并赋初值为 value。C语言float详解说明描述…

EF CodeFirst的步骤

1 创建各个实体类2 创建一个空数据模型&#xff0c;然后删除掉&#xff0c;为了引入Entity Framework和System.Data.Entity3 为实体类增加标注4 为实体增加导航属性5 在App.config configuration标签里面增加connectionStrings标签&#xff0c;并增加连接字符串6 创建数据操作类…

Block CONNECT method in httpd.conf

为什么80%的码农都做不了架构师&#xff1f;>>> RewriteEngine on RewriteCond %{REQUEST_METHOD} ^(CONNECT|TRACE)$ RewriteRule ^.*$ - [L,F] ProxyRequests Off ProxyRequest should be set to off, unless you have security protect in your web server. 转…

c语言基本字符集ppt,C语言的字符集和保留字知识讲稿.ppt

C语言的字符集和保留字知识讲稿.ppt第一章 概述 重点&#xff1a; C语言的字符集和保留字&#xff1b; C语言词类和语句的分类&#xff1b; C程序的基本结构。 程序——是对解决某个问题的方法的描述&#xff1b; 对计算机来说&#xff1a;程序是用某种计算机能够理解并执行的计…

linux利用patch和diff命令制作文件补丁

linux利用patch和diff命令制作文件补丁因为在 u-boot 移植过程中&#xff0c;有几处通用文件要修改&#xff0c;如果每次都要手动修改就太麻烦了。制作补丁可以解决这个问题。学习资料的收集比较简单&#xff0c;方法一类似于这种初级问题网上资料非常丰富&#xff0c; google …

c语言固定长度的字符串,【分享】C语言动态长度字符串

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼很多朋友都用惯了高级语言的字符串变量&#xff0c;就是定义一个字符串变量&#xff0c;直接可以赋值&#xff0c;但在C语言里没有字符串变量这样的概念&#xff0c;只有字符数组&#xff0c;因此&#xff0c;只能定义一个固定数组…

项目复审——Beta阶段

小组的名字和链接优点缺点&#xff0c;Bug报告最终名次颜罗王team http://www.cnblogs.com/LDLYMteam/p/9142408.html增加了单词学习功能&#xff0c;还有具体单词的音标解释&#xff0c;增加了pk功能&#xff0c;功能实现较为全面,想法新颖有特色1.pk功能还不是很完善偶尔会出…

解决sharepoint2010的多行文本框的插入图片—【从sharepoint】的disabled问题

大家发现sharepoint2010的多行文本框的插入图片有个—【从sharepoint】插入图片的功能&#xff0c;但是看到的disabled。如下图&#xff1a; 怎么办呢&#xff1f;通过查找资料才知道原来可以这样解决 在这里我们新建一个自定义列表&#xff1a;【test】&#xff0c;并新建一个…

c语言16进制按10进制输出,C语言编程:写一个函数,输入一个16进制数,输出相应的10进制数。...

满意答案chengexin2013.05.27采纳率&#xff1a;59% 等级&#xff1a;11已帮助&#xff1a;10599人#include#include#include#define N 1000char str[N];int a[N],b[N];int main(void){void zsh();long ycl();int i,n;do{printf("请输入一个十六进制数:\n");scanf…

用ASP.NET Core MVC 和 EF Core 构建Web应用 (一)

系统必备 .NET Core 2.0.0 SDK 或更高版本。已安装 ASP.NET 和 Web 开发工作负载的 Visual Studio 2017 15.3 版或更高版本。创建Web应用程序 打开 Visual Studio 并创建一个新 ASP.NET Core C# web 项目名为”ContosoUniversity”。 从文件菜单上&#xff0c;选择新建 > 项…

黑盒法测试c语言,黑盒测试用例练习题.pdf

黑盒测试用例设计练习题1、准考证号码对招干考试系统“输入学生成绩”子模块设计测试用例。招干考试分三个专业,准考证号第一位为专业代号&#xff0c;如&#xff1a;1-行政专业&#xff0c;2-法 专业&#xff0c;3-财经专业。行政专业准考证号码为 &#xff1a;110001&#xf…

HTML基础(格式标签)

<p></p> &#xff1a;段落标签 &#xff0c;默认属性为alignleft <p alignright>第一段 </p> <p alignleft>第二段 </p> <br> &#xff…

c语言equal,C ++中的ratio_equal()示例

在本文中&#xff0c;我们将讨论C STL中ratio_equal()函数的工作&#xff0c;语法和示例。什么是ratio_equal模板&#xff1f;ratio_equal模板内置在C STL中&#xff0c;该模板在头文件中定义。ratio_equal用于比较两个比率。该模板接受两个参数&#xff0c;并检查给定的比率…

//获取本地IP地址和对端IP地址

1 //获取本地IP地址2 CHAR * GetLocalIpAdrr(int fd)3 {4 struct sockaddr_in stHost;5 memset(&stHost, 0, sizeof(stHost));6 7 #ifdef _WIN328 INT iLen sizeof(stHost);9 #else 10 socklen_t iLen sizeof(stHost); 11 #endif 12 CHAR * szHostIp…

第一个Django应用程序_part1

一、查看Django是否安装 参考文档&#xff1a;https://docs.djangoproject.com/en/1.11/intro/tutorial01/ 如果Django已经安装&#xff0c;可以看到安装的版本号&#xff0c;如果没有安装则会看到“No module named django”的错误。 MacBook-Pro:~ h$ python3 -m django --ve…

rsa加密c语言源码库,RSA加密算法源代码C语言实现.doc-资源下载在线文库www.lddoc.cn...

RSA加密算法_源代码__C语言实现.docRSA 算法 1978 年就出现了这种算法&#xff0c;它是第一个既能用于数据加密也能用于数字签名的算法。它易于理解和操作&#xff0c;也很流行。算法的名字以发明者的名字命名Ron Rivest, AdiShamir 和 Leonard Adleman。但 RSA 的安全性一直未…

Apollo2.5摄像头安装

前言&#xff1a;在Apollo美研团队和长沙CiDi团队的支持下&#xff0c;最近完成了Apollo推荐的摄像头AR023ZWDR(Rev663F12)调试&#xff0c;在这里对Apollo的笔记做一个补充&#xff0c;希望以后的开发者不用在踩我们踩过的坑。 在本博客中提到的补充文件在我的百度网盘中&…

Linux下查看出口IP

使用的几个其他的命令&#xff0c;好像这个都不太靠谱。 但也想写一个很简单的程序就在服务器端的request里面能取得IP&#xff0c; 这个也有人已经在公网上有这样的程序啊 所以这个就简单了 wget http://members.3322.org/dyndns/getipcat getip 这样试试吧。

r语言教程w3c,R语言 数据库

数据是关系数据库系统以规范化格式存储。 因此&#xff0c;要进行统计计算&#xff0c;我们将需要非常先进和复杂的Sql查询。 但R语言可以轻松地连接到许多关系数据库&#xff0c;如MySql&#xff0c;Oracle&#xff0c;Sql服务器等&#xff0c;并从它们获取记录作为数据框。 一…

HTML 文档流和文本流的理解

文本流&#xff0c;概括地说其实就是一系列字符&#xff0c;是文档的读取和输出顺序&#xff0c;也就是我们通常看到的由左到右、由上而下的读取和输出形式&#xff0c;在网页中每个元素都是按照这个顺序进行排序和显示的&#xff0c;而position属性可以将元素从文本流脱离出来…