博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Mybatis通过注解方式实现批量插入数据库 及 常见的坑
阅读量:6935 次
发布时间:2019-06-27

本文共 2856 字,大约阅读时间需要 9 分钟。

原文地址:

MyBatis中通过xml文件配置批量操作的文章很多,比如这篇,但探讨如何通过注解配置实现同样效果的文章却很少,官方文档上也没找到相关的用法,其中的难点在于如何处理List或者Map类型的参数。不过这种方法终于被我试出来并且通过,现以批量插入为例,来演示一下怎样通过注解来实现数据库的批量操作:

/*User.java*/public class User {      private Integer id;      private String name; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
/*UserDAO.java*/public interface UserDAO { @InsertProvider(type = UserDAOProvider.class, method = "insertAll") void insertAll(@Param("list") List
users); }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5
/*UserDAOProvider.java*/public class UserDAOProvider {      public String insertAll(Map map) { List
users = (List
) map.get("list"); StringBuilder sb = new StringBuilder(); sb.append("INSERT INTO User "); sb.append("(id, name) "); sb.append("VALUES "); MessageFormat mf = new MessageFormat("(null, #'{'list[{0}].name})"); for (int i = 0; i < users.size(); i++) { sb.append(mf.format(new Object[]{i})); if (i < users.size() - 1) { sb.append(","); } } return sb.toString(); } }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

MyBatis会把UserDAO的insertAll方法中的List类型的参数存入一个Map中, 默认的key是”list”, 可以用@Param注解自定义名称, MyBatis在调用@InsertProvide指定的方法时将此map作为参数传入, 所有代码中使用List users = (List) map.get(“list”);获取list参数. 

可以从代码中看出生成的SQL语句大致为:

INSERT INTO User (id, name) VALUES (null, #{list[0].name}), (null, #{list[1].name})[,(null, #{list[i].name})]

其中#{list[0].name}就表示从List参数的取第0个元素的name的值了, “list”跟key是对应的。

http://blog.csdn.net/del_zhu/article/details/52711678

Mybatis常见配置错误总结

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="mapperLocations">
<list>
<value>classpath:com.axxxxxy/**/dao/mapper/*.xml</value>
</list>
</property>
<property name="dataSource" ref="dbcp2dataSource" />
<property name="configLocation" value="classpath:resources/mybatis/mybatis-config.xml"/>
</bean>
spring中的Mybatis的配置
1.classpath是针对src的,classpath后面跟的是路径名称而不是包名。
例如上面,com.axxxxy/**/dao/mapper/*.xml ,com后面应该是‘/’而不是'.',这个错误找了一天才找到。如果你classpath写了classpath*:,那么Mybatis会自动搜索查找子包

2.可以免Mapper接口实现类的,如果不用读写分离,dao接口对象可以直接被注入到Service,可以直接调用对应的Mapper ID

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.axxxxxy" />
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
<!-- <property name="annotationClass" value="org.springframework.stereotype.Repository"/> -->
</bean>

3.Mapper的DAO类的名称和对应XML的mapper文件文件名称应该一致(没试过)

4.最常见的错误有mapper XML文件的namespace,一定要确保数据表的Model路径配置正确了

5.DaoMapper接口中的方法 与 Mapper中的id不匹配,错别字或者 缺失,都是问题。

http://blog.csdn.net/cor_twi/article/details/51228516

 

你可能感兴趣的文章
我的友情链接
查看>>
20130527Linux学习1
查看>>
Qemu For ARM (1) : Install Qemu On LinuxMint
查看>>
开始学习设计模式
查看>>
suse10 linux 内核升级
查看>>
GIT 专贴
查看>>
Win2012R2 x64 安装MySQL5.7.14压缩版
查看>>
ProxmoxVE 之集群安装(V5.2)
查看>>
PHP中面向对象的分页类
查看>>
在Centos上安装使用GlusterFS
查看>>
Oracle纯SQL实现递归查询分页(树查询分页)
查看>>
【定制化图像开放平台】入门实例之手写数字模型训练
查看>>
Oracle 操作中的问题
查看>>
rabbitmq——prefetch count
查看>>
注册最新版Komodo, PDK , TDK
查看>>
shell study
查看>>
CSS 实现 0.5px 边框线
查看>>
Scala打印菱形*
查看>>
saas系统架构经验总结
查看>>
javascript闭包使用:解决循环绑定事件问题
查看>>