sql >> データベース >  >> RDS >> Mysql

SQLクエリのタイミングを見積もる方法は?

    これは、プロファイルの表示 を使用する場合に実行できます。 構文。MySQLセッションを開くときに、変数「プロファイリング」を1またはONに設定できます。

    mysql> SET profiling = 1;
    

    したがって、サーバーに送信されたすべてのステートメントは、プロファイルされて履歴に保存され、コマンドを入力して後で表示されます。

    mysql> SHOW PROFILES;
    

    MySQLマニュアルから参照してください:

    mysql> SET profiling = 1;
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> DROP TABLE IF EXISTS t1;
    Query OK, 0 rows affected, 1 warning (0.00 sec)
    
    mysql> CREATE TABLE T1 (id INT);
    Query OK, 0 rows affected (0.01 sec)
    
    mysql> SHOW PROFILES;
    +----------+----------+--------------------------+
    | Query_ID | Duration | Query                    |
    +----------+----------+--------------------------+
    |        0 | 0.000088 | SET PROFILING = 1        |
    |        1 | 0.000136 | DROP TABLE IF EXISTS t1  |
    |        2 | 0.011947 | CREATE TABLE t1 (id INT) |
    +----------+----------+--------------------------+
    3 rows in set (0.00 sec)
    
    mysql> SHOW PROFILE;
    +----------------------+----------+
    | Status               | Duration |
    +----------------------+----------+
    | checking permissions | 0.000040 |
    | creating table       | 0.000056 |
    | After create         | 0.011363 |
    | query end            | 0.000375 |
    | freeing items        | 0.000089 |
    | logging slow query   | 0.000019 |
    | cleaning up          | 0.000005 |
    +----------------------+----------+
    7 rows in set (0.00 sec)
    
    mysql> SHOW PROFILE FOR QUERY 1;
    +--------------------+----------+
    | Status             | Duration |
    +--------------------+----------+
    | query end          | 0.000107 |
    | freeing items      | 0.000008 |
    | logging slow query | 0.000015 |
    | cleaning up        | 0.000006 |
    +--------------------+----------+
    4 rows in set (0.00 sec)
    
    mysql> SHOW PROFILE CPU FOR QUERY 2;
    +----------------------+----------+----------+------------+
    | Status               | Duration | CPU_user | CPU_system |
    +----------------------+----------+----------+------------+
    | checking permissions | 0.000040 | 0.000038 |   0.000002 |
    | creating table       | 0.000056 | 0.000028 |   0.000028 |
    | After create         | 0.011363 | 0.000217 |   0.001571 |
    | query end            | 0.000375 | 0.000013 |   0.000028 |
    | freeing items        | 0.000089 | 0.000010 |   0.000014 |
    | logging slow query   | 0.000019 | 0.000009 |   0.000010 |
    | cleaning up          | 0.000005 | 0.000003 |   0.000002 |
    +----------------------+----------+----------+------------+
    


    参照(更新日:2014-09-04):
    -SHOWPROFILE構文
    -INFORMATION_SCHEMAプロファイリングテーブル
    -MySQLクエリプロファイリングの使用方法 Digital Oceanは最近、この問題に関するすばらしい記事を公開しました。




    1. tomcat7--jdbcdatasource-これはメモリリークを引き起こす可能性が非常に高いです

    2. Sysbenchを使用してMySQLでシャードテーブルのテストデータを生成する

    3. PHP MySQL SQLパーサー(INSERTおよびUPDATE)

    4. SQL Server FOR JSON PATHの例(T-SQL)