MySQL数据库连接串的两个参数:rewriteBatchedStatements=true&useCursorFetch=true

15 篇文章 0 订阅

最近在将数据库,从Oracle迁移到MySQL,遇到了不少数据库不同造成的问题,尤其是在批处理的时候,MySQL的表现和Oracle完全不一样,查了不少资料,问题解决了,除了程序部分,MySQL的数据库连接串上,要增加 useCursorFetch rewriteBatchedStatements 参数

useCursorFetch : 这个在前面的记录中已经写过,在查询大批量的数据时,MySQL是以FetchAll的方式,将所有的数据都堆到客户端的,要想使用stream方式,要通过 useCursorFetch 参数打开开关;这个参数mysql缺省是false的;(MySQL最低版本 5.0.2)(https://www.jianshu.com/p/64bd83f3bcc5

rewriteBatchedStatements:MyBatis 的批量方式,

  • 有 Mybatis Batch,
  • 原生JDBC Batch方式,
  • 以及Mybatis的foreach拼接SQL的方式

除了最后一种foreach拼接SQL的方式不受rewriteBatchedStatements影响,另两种方式,需要打开 rewriteBatchedStatements 参数,才能实现高性能的批量操作(MySQL最低驱动版本:5.1.13)

(资料: https://www.jianshu.com/p/0f4b7bc4d22c )

 

最近查资料解决问题,发现 简书 上大部分都有解决方法的文章,而且不仅文章质量比其他网站高,而且排版看着舒服,更容易看明白;大家有空可以看看;如果能翻墙找资料,那当然更好了;

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值