今日学习中遇见几个问题

关于mybatis foreach的几种情况

1.当我需要传入多个参数的时候,可以将参数封装进map集合中(一般来说是针对一个对象而言的,比如user中的username,gender,age等)

这里的name,gender均为map的key
参数map应为 Map<String,String> map=new HashMap<>();
map.put("name","chq");
map.put("gender","男");
List<User> list = userDao.findByMap(map); <select id="findByMap" parameterType="java.util.HashMap" resultType="user">
select * from user where username=#{name} and gender=#{gender}
</select>

当传入为多个对象的时候,我们就需要重新创建一个对象,这个对象中包含其他对象以及getter,setter方法

2.批量添加,首先 我们创建一个list集合,向集合中添加user对象,然后遍历,批量添加 注意这里的collection是list

 <insert id="insertBatch" parameterType="java.util.ArrayList"  >
insert into user(username,age,gender) values
<foreach collection="list" item="user" separator=",">
(#{user.userName},#{user.age},#{user.gender})
</foreach>
</insert> public void testInsertBatch() throws Exception{
List<User> list=new ArrayList<>();
User user1=new User();
user1.setUserName("111");
user1.setGender("女");
user1.setAge(33);
User user2=new User();
user2.setUserName("222");
user2.setGender("女");
user2.setAge(44);
User user3=new User();
user3.setUserName("333");
user3.setGender("女");
user3.setAge(55);
list.add(user1);
list.add(user2);
list.add(user3);
boolean b = userDao.insertBatch(list);
System.out.println(b);
}

3.当非一个对象的参数时候,我们可以把多个对象添加到map集合中,然后再去操作, 比如下方,我们map集合中有属性gender, 以及一个list

这个与重新重建一个实体类有什么区别呢? 个人见解: 好像没啥区别,就算到时候回传到前台时也是几乎差不多.....有哪位有好的见解欢迎留言....!!!!!!!!!!!

    <select id="findByMapMore" parameterType="java.util.Map" resultType="user">
select * from user where gender=#{gender} and uid in
<foreach collection="ids" item="item" index="index" open="(" separator="," close=")">
#{item}
</foreach>
</select> @Test
public void testFindByMapMore() throws Exception{
Map<String,Object> map=new HashMap<>();
map.put("gender","男");
List<Integer> list=new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
list.add(5);
map.put("ids",list);
List<User> users = userDao.findByMapMore(map);
for (User user:users){
System.out.println(user);
}
}

4.传入一个数组时,注意collection是array,


@Test
public void testFindByArray() throws Exception{
Integer[] arrays=new Integer[]{1,2,3,4,5};
List<User> list=userDao.findByArray(arrays);
for(User user:list){
System.out.println(user);
}
} <select id="findByArray" resultType="user">
select * from user where uid in
<foreach collection="array" open="(" separator="," close=")" index="index" item="id">
#{id}
</foreach>
</select>

mybatis 基础(二) CRUD中的关键点的更多相关文章

  1. mybatis 基础(二) xml文件中的其他知识点

    mybatis xml文件中一些标签的使用 此标签主要用作 配置 "别名" 如果实体类与数据库中字段名在不区分大小写的情况下相同的话, 那就不需要配置resultMap,因为mys ...

  2. Mybatis基础-完整CRUD操作

    步骤一:mybatis基本配置 1)创建Java项目,在lib下导入mybatis所需要的Jar包,包括链接mysql的mysql-connector-java-5.1.7-bin.jar. 2)在s ...

  3. mybatis 基础(二) 动态sql 关于where if / where choose when otherwise

    个人理解: where if就相当于正常的java中的if 语句,如果有多个条件组合判断的话用 and, or连接 而where choose when otherwise choose就好像是swi ...

  4. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  5. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...

  6. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  7. 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    [转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...

  8. Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】

    一.使用Mybatis对表进行CRUD操作------基于XML的实现 1.定义SQL的映射文件 2.在conf.xml中进行注册. 2.创建测试类 [具体过程参考:Mybatis的学习总结一] 二. ...

  9. MyBatis基础入门《二十》动态SQL(foreach)

    MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...

随机推荐

  1. 牛客网 Wannafly挑战赛3 B.遇见

    遇见 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 65536K,其他语言131072K64bit IO Format: %lld 题目描述 A和B在同一条路上,他们之间的距离为 k ...

  2. easyUI datagrid中checkbox选中事件以及行点击事件,翻页之后还可以选中

    DataGrid其中与选择,勾选相关 DataGrid属性:singleSelect boolean 如果为true,则只允许选择一行. false ctrlSelect boolean 在启用多行选 ...

  3. Sql Server 基本使用

    一.登录sql server数据库 1.若需要连接本机数据库服务器,服务器名可以采用“local”.“.”“本机Ip”. 2.在连接sql server 之前,确保sql server服务已经启动,如 ...

  4. jmeter操作登录等简单的使用

    一.登录 1.打开jmeter创建“线程组” 2.创建HTTP默认值 3.添加http默认值后,后边的http请求就可以省略填写部分内容 4.添加“HTTP信息管理头”在内添加名称:“Content- ...

  5. Nginx常见配置

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  6. 基于 XML 的 AOP 配置(1)

    本文连接:https://www.cnblogs.com/qzhc/p/11969734.html 接下来我将用一个很简单的实例 1. 环境搭建 1.1. 第一步:准备必要的代码 业务层代码: Acc ...

  7. LeetCode 130. 被围绕的区域(Surrounded Regions)

    题目描述 给定一个二维的矩阵,包含 'X' 和 'O'(字母 O). 找到所有被 'X' 围绕的区域,并将这些区域里所有的 'O' 用 'X' 填充. 示例: X X X X X O O X X X ...

  8. koa 基础(十八)es6中的类、静态方法、继承

    1.app.js /** * es6中的类.静态方法.继承 */ // 定义Person类 class Person { constructor(name, age) { /*类的构造函数,实例化的时 ...

  9. oc中枚举映射字符串技巧

    后台返枚举数据给app,app需要对不同枚举转换成字符串显示. 一般想到方法用 switch 根据不同枚举变量返回不同字符串,结果就是判断代码写得很长,不优雅.更简便方式有如下: typedef NS ...

  10. vmalloc详解

    vmalloc是一个接口函数, 内核代码使用它来分配在虚拟内存中连续但在物理内存中不一定连续的内存. 只需要一个参数,以字节为单位. 使用vmalloc的最著名的实例是内核对模块的实现. 因为模块可能 ...