问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

Mysql怎么确定储存过程是预编译的比普通sql执行的快

发布网友 发布时间:2022-04-30 19:19

我来回答

2个回答

懂视网 时间:2022-04-30 23:40

package exmysql; 2 3 import java.sql.Connection; 4 import java.sql.DriverManager; 5 import java.sql.ResultSet; 6 import java.sql.SQLException; 7 import java.sql.Statement; 8 import java.util.Date; 9 10 public class adddata { 11 12 private static long worker(){ 13 Date begin = new Date(); 14 15 String driver="com.mysql.jdbc.Driver"; 16 17 String url="jdbc:mysql://172.16.2.7:3306/testdb"; 18 19 Connection conn=null; 20 Statement stmt=null; 21 ResultSet rs=null; 22 23 try{ 24 Class.forName(driver); 25 conn=DriverManager.getConnection(url,"dbaadmin","123456"); 26 stmt=conn.createStatement(); 27 String sql; 28 for (int i=1;i<=5000;i++){ 29 sql="select * from test1 where id="+i; 30 rs=stmt.executeQuery(sql); 31 } 32 } 33 catch(SQLException | ClassNotFoundException e){ 34 e.printStackTrace(); 35 } 36 37 if(stmt!=null){ 38 try{ 39 stmt.close(); 40 } 41 catch(SQLException e){ 42 e.printStackTrace(); 43 } 44 } 45 46 if(conn!=null){ 47 try{ 48 conn.close(); 49 } 50 catch(SQLException e){ 51 e.printStackTrace(); 52 } 53 } 54 55 Date end = new Date(); 56 return end.getTime()-begin.getTime(); 57 } 58 59 public static void main(String[] args) { 60 // TODO Auto-generated method stub 61 62 long elapsed,average; 63 average=0; 64 for (int i=1;i<=10;i++){ 65 elapsed=worker(); 66 System.out.println("elapsed time(ms):"+elapsed); 67 average=average+elapsed; 68 } 69 System.out.println("average time(ms):"+average/10); 70 } 71 72 }

结果如下:

elapsed time(ms):24652
elapsed time(ms):13380
elapsed time(ms):13250
elapsed time(ms):13877
elapsed time(ms):13275
elapsed time(ms):13193
elapsed time(ms):19022
elapsed time(ms):13558
elapsed time(ms):14138
elapsed time(ms):13364
average time(ms):15170

 

2.同样的sql用PreparedStatement预编译执行

 

 1 package exmysql;
 2 
 3 import java.sql.*;
 4 import java.util.Date;
 5 
 6 public class insert_data {
 7 
 8 private static long worker(){
 9  Date begin = new Date(); 
10  
11  String driver="com.mysql.jdbc.Driver";
12 
13  String url="jdbc:mysql://172.16.2.7:3306/testdb";
14  
15  Connection conn=null;
16  PreparedStatement pstm=null;
17  ResultSet rs=null;
18  
19  try{
20   Class.forName(driver);
21  conn=DriverManager.getConnection(url,"dbaadmin","123456");
22  conn.setAutoCommit(false);
23  String sql="select * from test1 where id=?";
24  pstm=conn.prepareStatement(sql);
25  for(int i=1;i<=5000;i++){
26   pstm.setInt(1, i);
27   rs=pstm.executeQuery();
28   }
29   conn.commit();
30  
31  }
32  catch(SQLException | ClassNotFoundException e){
33   e.printStackTrace();
34  }
35  
36  if(pstm!=null){
37  try{
38   pstm.close();
39   }
40  catch(SQLException e){
41   e.printStackTrace();
42   }
43  }
44  
45  if(conn!=null){
46  try{
47   conn.close();
48   }
49  catch(SQLException e){
50   e.printStackTrace();
51   }
52  }
53  
54  Date end = new Date(); 
55  return end.getTime()-begin.getTime();
56  }
57 
58 public static void main(String[] args) {
59  // TODO Auto-generated method stub
60  
61  long elapsed,average;
62  average=0;
63  for (int i=1;i<=10;i++){
64  elapsed=worker();
65  System.out.println("elapsed time(ms):"+elapsed);
66  average=average+elapsed;
67  }
68  System.out.println("average time(ms):"+average/10);
69  }
70 
71 }

结果如下:

elapsed time(ms):14773
elapsed time(ms):16352
elapsed time(ms):14797
elapsed time(ms):15800
elapsed time(ms):12069
elapsed time(ms):14953
elapsed time(ms):13238
elapsed time(ms):12366
elapsed time(ms):15263
elapsed time(ms):13089
average time(ms):14270

 

可以看出两种方式执行的结果几乎相同,不像Oracle差距那么大。而且就算是用PreparedStatement的方式,在Mysql数据库端抓出来的sql语句也不是以变量id=?的形式出现的,而是实际的数值。后来在网上看到在连接字符串上加上useServerPrepStmts=true可以实现真正的预编译

 String url="jdbc:mysql://172.16.2.7:3306/testdb";
 url=url+"?useServerPrepStmts=true";

加上这段后可以在数据库端可以看到明确的结果:

mysql> show global status like ‘Com_stmt_prepare‘;
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| Com_stmt_prepare | 11 |
+------------------+-------+
1 row in set (0.00 sec)

 

但是实际的运行结果和上面几乎一样,性能上没有任何的提升。由此可以推断出Mysql由于缺少类似于Oracle的library cache的部件,因此采用预编译方式执行sql是没有性能上的提升的。

 

测试mysql的sql语句预编译效果

标签:

热心网友 时间:2022-04-30 20:48

SET @update_stmt='' /*在单引号中间填入要执行的sql语句*/
PREPARE stmt FROM @update_stmt;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
母爱作文(围绕一句话来写)900字 月经期能喝冰糖沙梨水? 石家庄火车站骗钱 五等分的新娘手游汉化安卓游戏官方下载 昆明看守所那个看守所好在 成建军行政拘留 青岛贵捷充换电设备成套服务有限公司怎么样? 合肥贵捷商贸有限责任公司怎么样? 南京贵捷物资有限公司怎么样? 上海贵捷电气有限公司产品用途 家有两个老人 57岁,只买了农村医疗保险,请问有什么重大疾病保险可以购买吗? 电子烟危害更大? 公司级局域网IP地址冲突 赣州市久治物业管理有限公司梧州毅德分公司怎么样? 赣州市吉雅家政服务有限公司怎么样? 公司网IP地址冲突 赣州市通保中央空调技术服务有限公司怎么样? 赣州市国华家政服务有限公司怎么样? 公司IP地址冲突 各位,赣州空调清洗加盟哪家好? 江西源美清洁服务有限公司怎么样? 赣州康宁环境技术服务有限公司怎么样? 谁有很多现金微信拍的视频?跪求&#xF62D;&#xF62D; 自己拍视频怎么赚钱? 企业的小程序,客户支付了,能不能不到对公账户,到法人的银行卡可以吗!只要不到对公账户,都可以! 古代皇后头饰制作,是模具还是手工 贷款四十万,正常供房一年半,现提前还款十万,为何交违约金,还款利息怎么算? 提前还款违约金怎么计算 抖音进别人直播间后为什么多了个粉色“饭”的标签? 怎么安装声卡驱动啊?求助电脑高手帮我整下电脑万分感激 有什么赚钱手机软件能提现到QQ钱包里? 昨天下午上完课 回到家后 感觉脚心特别的痒 于是我就用手挠了挠~也没再意~。。。 预编译SQL语句的使用问题 凯利U盘怎么样?好不好?值不值得买? 从道外太古五道街到江北凯利广场坐几线车能到 凯利公司生日礼物有些什么 买到了黑芯u盘,主控安国fc8030,源盘容量4g经过软件检测后实际容量16m,我擦啊该死的奸商,太狗血了吧? 如何玩冷门大小球走地 假如记忆可以移植 请可爱的你们推荐我2部电影看看- -!!! kali能使用360浏览器吗 求国外国内好看的悬疑片 这个车智汇有什么用? kali linux 2 0怎么安装firbox浏览器 足球单率是什么意思 kali linux安装了浏览器怎么添加快捷方式 世界20大最卖座电影 12306绑定了其它人手机号,携程上买票,他能收到信息吗? 求电脑达人帮忙看看.这配置能玩DNF吗? 电脑升级请大虾提些建议