この記事では、MySQLのプリコンパイル機能について紹介します。具体的な内容は以下のとおりです。 1. プリコンパイルの利点 私たちは皆、プリコンパイル機能を備えた JDBC の PreparedStatement インターフェイスを使用したことがあります。プリコンパイル機能とは何ですか?それのメリットは何ですか? 2. MySQLはプリコンパイルを実行する MySQL は、次の 3 つのステップでプリコンパイルを実行します。 3. ステートメントを使用してプリコンパイルを実行する ステートメントを使用してプリコンパイルを実行すると、上記の SQL ステートメントが 1 回実行されます。 接続 con = JdbcUtils.getConnection(); ステートメント stmt = con.createStatement(); stmt.executeUpdate("'select * from t_book where bid=?' から myfun を準備します"); stmt.executeUpdate("@str='b1' を設定"); ResultSet rs = stmt.executeQuery("@str を使用して myfun を実行します"); 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("@str='b2' を設定"); rs = stmt.executeQuery("@str を使用して myfun を実行します"); 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 より前のバージョンではプリコンパイルがサポートされておらず、5.0.5 以降の Connector/J バージョンではデフォルトでプリコンパイルが有効になっていません。 例: jdbc:mysql://localhost:3306/test?useServerPrepStmts=true 接続 con = JdbcUtils.getConnection(); 文字列 sql = "select * from t_book where bid=?"; 準備されたステートメント pstmt = con.prepareStatement(sql); pstmt.setString(1, "b1"); 結果セット 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 ステートメントを実行すると、ステートメントは 2 回コンパイルされます。これは、ドライバーがコンパイルされた関数キーをキャッシュしないため、2 回目のコンパイルが発生するためです。コンパイルされた関数のキーをキャッシュする場合は、cachePrepStmts パラメータを true に設定します。例えば: 接続 con = JdbcUtils.getConnection(); 文字列 sql = "select * from t_book where bid=?"; 準備されたステートメント pstmt = con.prepareStatement(sql); pstmt.setString(1, "b1"); 結果セット 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 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: CentOS での Docker の詳細なインストール チュートリアル
>>: CocosCreator で http と WebSocket を使用する方法
インストールtsコマンドをグローバルにインストールする npm install -g typescr...
ただし、デフォルトの src を持つ <img> 要素を使用してスクロール読み込み効果を...
序文ブロガーが使用しているサーバーは Alibaba Cloud から購入したものです。実際、Ali...
一番外側の boxF は 120 度回転し、2 番目の boxS は -60 度回転し、3 番目の ...
この記事では、MySQL インストールの詳細なチュートリアルを記録し、全員と共有します。 1. バー...
1. 依存パッケージをインストールする [root@localhost ~]# yum insta...
基本的な準備この実装には、クラス名が ball である単純な div が必要です。 HTMLコード:...
目次モジュール化の基本概念モジュール化とは何かモジュール分解の利点Node.js のモジュール性No...
本文に入る前に、オーバーフローとフレックスレイアウトの使い方をいくつか紹介します。 overflow...
目次1. リソースファイル2. インストール2.1 詳細な手順2.1.1 ディスクイメージのマウント...
目次導入1. MySQLデータベースの全体的なアーキテクチャSQL インターフェースパーサーオプティ...
最近、データベースについて学び始めました。最初にやったことは、データベースとは何か、データベースとデ...
<br />ナビゲーションとは、ウェブサイトの上部にあることが多いナビゲーション バーの...
目次forEach() メソッドjs の Array.forEach のループから抜け出す方法解決:...
この記事では、圧縮パッケージから MySQL をインストールする方法について説明します。 1. My...