This article shares the MySQL precompilation function for your reference. The specific content is as follows 1. Benefits of precompilation We have all used the PreparedStatement interface in JDBC, which has a precompilation function. What is the pre-compilation function? What are the benefits of it? 2. MySQL performs precompilation MySQL performs precompilation in three steps: 3. Use Statement to perform precompilation Using Statement to execute precompilation is to execute the above SQL statement once. 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 parameter By default, PreparedStatement cannot be precompiled. This requires the useServerPrepStmts=true parameter to be given in the URL (MySQL Server Versions prior to 4.1 do not support precompilation, and Connector/J versions after 5.0.5 do not enable precompilation by default). For example: jdbc:mysql://localhost:3306/test?useServerPrepStmts=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.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 parameters When using different PreparedStatement objects to execute the same SQL statement, it will still be compiled twice. This is because the driver does not cache the compiled function key, resulting in secondary compilation. If you want to cache the key of the compiled function, set the cachePrepStmts parameter to true. For example: 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. Turn on batch processing MySQL batch processing also needs to be turned on through parameters: rewriteBatchedStatements=true The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. You may also be interested in:
|
<<: Detailed installation tutorial of Docker under CentOS
>>: How to use http and WebSocket in CocosCreator
Description of port availability detection when p...
Preface Semicolons in JavaScript are optional, an...
I encountered several problems when installing My...
Usually a CSS selector selects from top to bottom...
1. Select Edit → Virtual Network Editor in the me...
Implementation of time comparison in MySql unix_t...
Table of contents 1. Some concepts you need to un...
Table of contents Stabilization Throttling Summar...
Page layout has always been my concern since I st...
In the previous article, I introduced the functio...
The implementation idea of the javascript game ...
Written in front No matter how well the code is w...
This article example shares the specific code of ...
Table of contents 1. JavaScript Objects 1).Array ...
Unzip the file into a directory This is the direc...