作为CRUD程序员,大部分Java开发者应该都在用Mybatis Plus来操作数据库。但是BaseMapper默认仅提供了int insert(T entity)这个单条插入的方法。那么我们想批量插入数据该怎么办呢?
在驻马店等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供做网站、成都网站制作 网站设计制作按需设计,公司网站建设,企业网站建设,品牌网站建设,全网营销推广,外贸网站建设,驻马店网站建设费用合理。
在以前用Mybatis的时候,我们会在Mapper.xml里面去写foreach循环:
1 |
insert into user (user_name,create_time) |
如果批量的实体对象较多的话,我们就会写很多这样的Mapper,如果表字段较多,这工作量的也不小的,当然,如果你用了代码生成工具,那就当我没说。Mybatis Plus作为Mybatis的增强版,也为我们考虑到了这个问题。使用Mybatis Plus批量插入数据有两种方式,第一种是Service层继承IService,第二种便是insertBatchSomeColumn。先来看看IService的方式
这种方式,会生成多条INSERT语句一条条执行,然后按设置的batchSize来提交事务。
我们再来看看insertBatchSomeColumn是怎么做的呢。1.新建一个InsertBatchInjector类来扩展DefaultSqlInjector
1 |
@Component |
2.新建一个Mapper接口,继承BaseMapper
1 |
@Mapper |
3.在要批量写的地方直接调用该Mapper的insertBatchSomeColumn即可
1 |
public void batchAddUser() { |
这种方式则是拼接成一条SQL,一次性提交到数据库执行
这里,SQL语句的长度受MySQL服务端的max_allowed_packet参数限制,默认为1M,如果拼接的字符串过长则会报错。可以进来减少批量提交的记录,或者是调整max_allowed_packet参数的大小。除了受到max_allowed_packet的影响,innodb_buffer_pool_size的大小也会影响批量的记录数大小,innodb_buffer_pool_size的默认值为128M,我们可以根据情况适当调整,合理地配置innodb_buffer_pool_size参数,可以提高MySQL的读写性能。
新闻名称:Mybatis Plus批量插入数据到MySQL中
标题链接:http://www.shufengxianlan.com/qtweb/news14/246964.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联