亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL預編譯功能詳解

2024-07-24 13:14:34
字體:
來源:轉載
供稿:網友

本文為大家分享了MySQL預編譯功能,供大家參考,具體內容如下

1、預編譯的好處

  大家平時都使用過JDBC中的PreparedStatement接口,它有預編譯功能。什么是預編譯功能呢?它有什么好處呢?
  當客戶發送一條SQL語句給服務器后,服務器總是需要校驗SQL語句的語法格式是否正確,然后把SQL語句編譯成可執行的函數,最后才是執行SQL語句。其中校驗語法,和編譯所花的時間可能比執行SQL語句花的時間還要多。
  如果我們需要執行多次insert語句,但只是每次插入的值不同,MySQL服務器也是需要每次都去校驗SQL語句的語法格式,以及編譯,這就浪費了太多的時間。如果使用預編譯功能,那么只對SQL語句進行一次語法校驗和編譯,所以效率要高。

2、MySQL執行預編譯

MySQL執行預編譯分為如三步:
執行預編譯語句,例如:prepare myfun from 'select * from t_book where bid=?'
設置變量,例如:set @str='b1'
執行語句,例如:execute myfun using @str
如果需要再次執行myfun,那么就不再需要第一步,即不需要再編譯語句了:
設置變量,例如:set @str='b2'
執行語句,例如:execute myfun using @str
通過查看MySQL日志可以看到執行的過程:

MySQL,預編譯

3、使用Statement執行預編譯

使用Statement執行預編譯就是把上面的SQL語句執行一次。

Connection con = JdbcUtils.getConnection();Statement stmt = con.createStatement();stmt.executeUpdate("prepare myfun from 'select * from t_book where bid=?'");stmt.executeUpdate("set @str='b1'");ResultSet rs = stmt.executeQuery("execute myfun using @str");while(rs.next()) { System.out.print(rs.getString(1) + ", "); System.out.print(rs.getString(2) + ", "); System.out.print(rs.getString(3) + ", "); System.out.println(rs.getString(4));}stmt.executeUpdate("set @str='b2'");rs = stmt.executeQuery("execute myfun using @str");while(rs.next()) { System.out.print(rs.getString(1) + ", "); System.out.print(rs.getString(2) + ", "); System.out.print(rs.getString(3) + ", "); System.out.println(rs.getString(4));}rs.close();stmt.close();con.close();

4、useServerPrepStmts參數

  默認使用PreparedStatement是不能執行預編譯的,這需要在url中給出useServerPrepStmts=true參數(MySQL Server

4.1之前的版本是不支持預編譯的,而Connector/J在5.0.5以后的版本,默認是沒有開啟預編譯功能的)。

  例如:jdbc:mysql://localhost:3306/test?useServerPrepStmts=true
  這樣才能保證mysql驅動會先把SQL語句發送給服務器進行預編譯,然后在執行executeQuery()時只是把參數發送給服務器。

Connection con = JdbcUtils.getConnection();String sql = "select * from t_book where bid=?";PreparedStatement pstmt = con.prepareStatement(sql);pstmt.setString(1, "b1");ResultSet rs = pstmt.executeQuery();while(rs.next()) { System.out.print(rs.getString(1) + ", "); System.out.print(rs.getString(2) + ", "); System.out.print(rs.getString(3) + ", "); System.out.println(rs.getString(4));}pstmt.setString(1, "b2");rs = pstmt.executeQuery();while(rs.next()) { System.out.print(rs.getString(1) + ", "); System.out.print(rs.getString(2) + ", "); System.out.print(rs.getString(3) + ", "); System.out.println(rs.getString(4));}rs.close();pstmt.close();con.close();

5、cachePrepStmts參數

  當使用不同的PreparedStatement對象來執行相同的SQL語句時,還是會出現編譯兩次的現象,這是因為驅動沒有緩存編譯后的函數key,導致二次編譯。如果希望緩存編譯后函數的key,那么就要設置cachePrepStmts參數為true。例如:
  jdbc:mysql://localhost:3306/test?useServerPrepStmts=true&cachePrepStmts=true

Connection con = JdbcUtils.getConnection();String sql = "select * from t_book where bid=?";PreparedStatement pstmt = con.prepareStatement(sql);pstmt.setString(1, "b1");ResultSet rs = pstmt.executeQuery();while(rs.next()) { System.out.print(rs.getString(1) + ", "); System.out.print(rs.getString(2) + ", "); System.out.print(rs.getString(3) + ", "); System.out.println(rs.getString(4));}pstmt = con.prepareStatement(sql);pstmt.setString(1, "b2");rs = pstmt.executeQuery();while(rs.next()) { System.out.print(rs.getString(1) + ", "); System.out.print(rs.getString(2) + ", "); System.out.print(rs.getString(3) + ", "); System.out.println(rs.getString(4));}rs.close();pstmt.close();con.close();

6、打開批處理

MySQL的批處理也需要通過參數來打開:rewriteBatchedStatements=true

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产在线精品播放| 国产精品9999| 中国人与牲禽动交精品| 色与欲影视天天看综合网| 日韩在线播放视频| 亚洲欧美日韩精品久久| 色偷偷亚洲男人天堂| 精品国产老师黑色丝袜高跟鞋| 午夜精品99久久免费| 欧美专区中文字幕| 国产精品视频中文字幕91| 色综合天天综合网国产成人网| 在线视频免费一区二区| 4444欧美成人kkkk| 国产精品igao视频| 欧美日韩国产色视频| 奇米成人av国产一区二区三区| 亚洲第一页中文字幕| 亲子乱一区二区三区电影| 蜜月aⅴ免费一区二区三区| 国产精品欧美一区二区三区奶水| 欧美日韩免费看| 国产精品美女www爽爽爽视频| xxx一区二区| 日本一欧美一欧美一亚洲视频| 国产69精品久久久| 欧美精品在线看| 日韩精品视频免费在线观看| 亚洲欧洲高清在线| 欧美一级黑人aaaaaaa做受| 国产日本欧美视频| 97久久超碰福利国产精品…| 欧美日韩在线第一页| 久久久久久久久久久亚洲| 日韩精品福利在线| 国产色综合天天综合网| 久久久久北条麻妃免费看| 伊人久久久久久久久久久久久| 国产一区二区三区免费视频| 欧美电影在线观看高清| 国产亚洲欧美日韩精品| 精品一区二区三区四区在线| 中文字幕亚洲一区在线观看| 久久久电影免费观看完整版| 亚洲自拍av在线| 伦伦影院午夜日韩欧美限制| 久久久久国色av免费观看性色| 狠狠躁夜夜躁人人爽天天天天97| 菠萝蜜影院一区二区免费| 日韩中文在线中文网三级| 91免费福利视频| 日韩一区二区三区在线播放| 久久精品电影网| 久久久久一本一区二区青青蜜月| 国产精品电影网| 国产精品白嫩美女在线观看| 国产欧美久久久久久| 午夜精品三级视频福利| 国产精品入口尤物| 久久久伊人欧美| 日韩电影在线观看永久视频免费网站| 亚洲第一综合天堂另类专| 精品亚洲一区二区三区在线播放| 亚洲最大av在线| 精品国产欧美成人夜夜嗨| 日韩欧美在线观看视频| 久久国产精品久久久久久久久久| 久久91精品国产| 国产欧美久久久久久| 国产原创欧美精品| 一区二区在线视频播放| 精品国产自在精品国产浪潮| 日韩精品在线观看一区二区| 韩国视频理论视频久久| 亚洲最大激情中文字幕| 国产成人高潮免费观看精品| 亚洲在线免费视频| 亚洲嫩模很污视频| 色综合久久88色综合天天看泰| 国产精品久久久久久久久久久久久久| 色偷偷噜噜噜亚洲男人的天堂| 欧美日韩成人网| 国产亚洲欧洲在线| 亚洲精品免费一区二区三区| 欧美精品久久久久| 国产精品视频最多的网站| 久久影视电视剧凤归四时歌| 久久久久久久色| 亚洲激情在线视频| 国产精品一区二区av影院萌芽| 成人黄色在线免费| 欧美大成色www永久网站婷| 91网站免费观看| 中文字幕久久久av一区| 国产精品一区二区三区久久久| 夜夜嗨av一区二区三区四区| 欧美老女人xx| 疯狂做受xxxx高潮欧美日本| 国产偷国产偷亚洲清高网站| 久久免费福利视频| 午夜精品一区二区三区视频免费看| 91国产精品电影| 亚洲欧美一区二区精品久久久| 国产精品美女无圣光视频| 久久久久久久久网站| 一区二区三区动漫| 国产精品一区二区三区毛片淫片| 欧美亚洲国产精品| 日韩精品久久久久久福利| 日韩中文视频免费在线观看| 日韩av在线影视| 欧洲成人在线视频| 久久精品国产亚洲一区二区| 久久成人精品电影| zzjj国产精品一区二区| 97精品视频在线观看| 久久久国产一区二区| 欧美一区二区大胆人体摄影专业网站| 亚洲aⅴ男人的天堂在线观看| 欧美视频第一页| 日韩av网址在线观看| 色综合色综合网色综合| 亚洲天堂色网站| 国产精品福利在线观看| 伊人久久免费视频| 日韩欧美亚洲范冰冰与中字| 色噜噜久久综合伊人一本| 亚洲色图激情小说| 中文字幕欧美日韩在线| 欧美性猛交xxxx乱大交| 国产精品99久久久久久久久久久久| 国产视频在线一区二区| 国产精品视频公开费视频| 欧美日韩国产区| 国产欧美亚洲视频| 欧美超级免费视 在线| 91久久嫩草影院一区二区| 午夜剧场成人观在线视频免费观看| 欧美一级视频一区二区| 欧美精品一区二区三区国产精品| 亚洲欧美激情四射在线日| 国产精品久久久久久亚洲影视| 久久免费精品日本久久中文字幕| 91久久嫩草影院一区二区| 伊人久久久久久久久久| 91成人免费观看网站| 日本一区二区三区在线播放| 91九色单男在线观看| 国产精品视频yy9099| 91国内产香蕉| 亚洲国产成人久久| 国产精品精品一区二区三区午夜版| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品视频在线观看| 欧美成在线观看| 国产欧美日韩免费| 色综合视频一区中文字幕| 91精品久久久久久久久中文字幕| 久久99热精品| 国产第一区电影| 欧美性感美女h网站在线观看免费| 国产精品丝袜一区二区三区| 粉嫩老牛aⅴ一区二区三区| 亚洲人成在线播放|