ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

mysql 注意事项 PreparedStatement 对比 statement

2019-12-06 10:07:01  阅读:270  来源: 互联网

标签:语句 PreparedStatement statement mysql amp 100 执行


1 查询语句不写* 而写具体的所用字段,因为实际执行时候,会把*转为所用字段,多了一层,效率降低,所以我们直接写各个字段.

2 对于只执行一次的SQL语句选择Statement是最好的. 相反, 如果SQL语句被多次执行选用PreparedStatement是最好的.

3 PreparedStatement的第一次执行消耗是很高的. 与statement相比 增加了一次的网络.它的性能优势体现在后面的重复执行.  

4 使用PreparedStatement的Batch功能

 

5 PreparedStatement被用来多次执行INSERT语句. 在这里, 执行了100次INSERT操作, 共有101次网络往返.

6 第一次往返是预储PreparedStatement, 另外100次往返执行每个迭代.

7 当在100次INSERT操作中使用addBatch()方法时, 只有两次网络往返. 一次预编译 一次提交batch.

 

8 mysql 5.5 批量执行的数据最大限度是多少不清楚,1w,2w,3w 都没问题

9 在url 后面添加:rewriteBatchedStatements=true 表示批量插入

10 如果不添加的话使用addbatch() ,executeBatch() 在后台入库的地方,还是不会一次请求入库而是多次请求入库。

 

addBatch() 就是把你的处理内容添加到批处理单元中。

即添加到了batch中。可以循环加入很多,数据库都不会处理,直到调用如下代码executeBatch() 此时,数据库把刚才加到batch中的命令批量处理。

url="jdbc:mysql://localhost:3306/music?rewriteBatchedStatements=true";

 

mysql 5.7  c3p0 config中 

<property name="jdbcUrl">jdbc:mysql://localhost:3306/bookstore?&amp;useSSL=false&amp;serverTimezone=UTC</property>
参数前 多了一个&amp;

标签:语句,PreparedStatement,statement,mysql,amp,100,执行
来源: https://www.cnblogs.com/liubosong/p/11993525.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有