当前位置: 首页 > wzjs >正文

四川兴昌建设有限公司网站怎么看百度指数

四川兴昌建设有限公司网站,怎么看百度指数,网站设置ico,树洞app开发公司工作中遇到批量更新的场景其实是比较常见的。 但是该如何正确的进行批量UPDATE,很多时候往往有点头大。 这里列2种可用的方式,供选择(请选择方式一,手动狗头。)。 如果使用了MyBatis增强组件MyBatisPlus 如果使用了MyBatisPlus,…

工作中遇到批量更新的场景其实是比较常见的。
但是该如何正确的进行批量UPDATE,很多时候往往有点头大。
这里列2种可用的方式,供选择(请选择方式一,手动狗头。)。

如果使用了MyBatis增强组件MyBatisPlus

如果使用了MyBatisPlus,可以参考官网给出的解决方式(updateBatchById),或者自己查一下。


批量UPDATE方式一:SQL内foreach

举个??

<update id="updateUserForBatch" parameterType="com.bees.srx.entity.UserEntity"><foreach collection="list" item="entity" separator=";">UPDATE sys_userSET password=#{entity.password},age=#{entity.age}<where>id = #{entity.id}</where></foreach>
</update>

这样写,肯定比 在业务方法中for循环单条update的效率是要高的。
但是如果遇到大批量的更新动作,可能也会产生效率低下的问题。
原因是SQL内的foreach本质上还是循环插入每一条数据,会产生 list.size() 个单条插入的独立SQL语句,每一条 UPDATE 语句都会被单独发送到数据库服务器执行。
这意味着如果列表中有100个元素,就会产生100次数据库往返通信。
这种方式不仅效率低下,而且对于大型批处理操作来说,可能会导致性能瓶颈和资源浪费。

优化:通过JDBC批处理
通过 MyBatisSqlSession 提供的批处理功能来手动执行批量更新。

try (SqlSession session = sqlSessionFactory.openSession(ExecutorType.BATCH)) {UserMapper mapper = session.getMapper(UserMapper.class);for (UserEntity user : userList) {mapper.updateUser(user);}session.commit();
}

这里mapper.updateUser就是单条的UPDATE语句。

通过这种方式,MyBatis 会在内存中积累所有的更新命令,然后在调用session.commit() 时一次性提交给数据库,这比逐条执行要高效得多。

注意:是否存在效率差异,未实践过!!!可能存在误人子弟的嫌疑。

批量UPDATE方式二:INSERT + ON DUPLICATE KEY UPDATE
 <update id="updateForBatch" parameterType="com.bees.srx.entity.UserEntity">insert into sys_user(id,username,password) values<foreach collection="list" index="index" item="item" separator=",">(#{item.id},#{item.username},#{item.password})</foreach>ON DUPLICATE KEY UPDATEpassword=values(password)
</update>

不建议使用。要求较多,而且容易出现死锁。

注意事项

  • 唯一键约束:确保 sys_user 表中的 id 字段有唯一键约束(通常是主键)。如果 id 不是唯一的,ON DUPLICATE KEY UPDATE 将不会触发更新操作。
  • 性能:这种方式在大数据量的情况下比多次单独的 INSERT 和 UPDATE 操作要高效得多。
  • 事务管理:确保这个操作在一个事务中执行,以保证数据的一致性。如果中间发生错误,可以回滚整个操作。
  • 字段顺序:确保 VALUES 函数中的字段顺序与 ON DUPLICATE KEY UPDATE 子句中的字段顺序一致。
总结:

建议使用方式一,或者其优化方式(JDBC批处理)。
各位也可以与AI对话看看给出的建议是什么。


有问题一定要留言啊各位。及时发现及时改错。

http://www.dtcms.com/wzjs/460148.html

相关文章:

  • 黑彩网站开发网络销售怎么聊客户
  • 外贸推广B2B网站建设国际最新十大新闻事件
  • 百度做的网站能优化吗怎么注册中视频账号
  • 国内服务器做彩票网站安全吗怎么建立信息网站平台
  • 做网站建设公司怎么样关键词app下载
  • 成都网站搭建公司哪家便宜公司网站建设哪家公司好
  • 写作的网站有哪些天眼查企业查询入口
  • 本网站建设中网络营销策划方案ppt
  • 商务型网站有哪些优化网站关键词排名软件
  • 软件公司网站建设刷赞网站推广永久
  • 中国舆情监测公司排名狼雨seo网站
  • 浙江第一水电建设集团网站电话投放小网站
  • 公司网站建设流程新网域名注册查询
  • wordpress修改登陆地址后缀长春网站seo公司
  • 国外设计素材网站免费桂林网站设计制作
  • 有什么手机做网站的网站建设优化收费
  • 邯郸网站制作地方百度搜索引擎地址
  • java从入门到精通2022年搜索引擎优化指南
  • 进出口网站贸易平台有哪些推广渠道有哪些平台
  • 阿里云网站全部清空怎么做太原seo外包公司
  • 深圳网站建设设计制作怎样做好销售和客户交流
  • 奎屯建设局网站网站seo诊断报告怎么写
  • 深圳网站建设工作网易最新消息新闻
  • 用阿里云做网站会不会被黑搜索引擎优化的英语简称
  • 新站网站推广该如何做营销渠道方案
  • 网站设计动图怎么建设大型的营销型网站
  • 河南做网站汉狮廊坊关键词优化排名
  • 加盟品牌网站建设36优化大师下载安装
  • 武汉教育云平台网站建设预防电信网络诈骗
  • ps做网站的时候分辨率是多层次网络营销合法吗