查询某段时间内请求次数排在 TOP N 的 SQL

运行如下语句可以查询某段时间内请求次数排在 TOP N 的 SQL:

obclient>SELECT/*+ PARALLEL(15)*/ SQL_ID, COUNT(*) AS QPS, AVG(t1.elapsed_time) RT                 FROM oceanbase.gv$sql_audit t1 WHERE tenant_id = 1001 AND                 IS_EXECUTOR_RPC = 0 AND request_time > (time_to_usec(now()) - 10000000)  AND                 request_time < time_to_usec (now())                 GROUP BY t1.sql_id ORDER BY QPS DESC LIMIT 10;+----------------------------------+------+------------+| SQL_ID                           | QPS  | RT         |+----------------------------------+------+------------+| BF7AA13A28DF50BA5C33FF19F1DBD8A9 | 2523 |  4233.2085 || CE7208ADDE365D0AB5E68EE24E5FD730 | 1268 |  5935.8683 || E5C7494018989226E69AE7D08B3D0F15 | 1028 |  7275.7490 || D0E8D8C937E44BC3BB9A5379AE1064C5 | 1000 | 12999.1640 || 2D45D7BE4E459CFBEAE4803971F0C6F9 | 1000 |  8050.6360 || C81CE9AA555BE59B088B379CC7AE5B40 | 1000 |  6865.4940 || BDC4FE903B414203A04E41C7DDA6627D | 1000 | 12751.8960 || B1B136047D7C3B6B9125F095363A9D23 |  885 | 13293.2237 || 47993DD69888868E92A7CAB2FDE65380 |  880 |  7282.0557 || 05C6279D767C7F212619BF4B659D3BAB |  844 | 11474.5438 |+----------------------------------+------+------------+

查询某段时间内平均 RT 排在 TOP N 的 SQL

运行如下语句可以查询某段时间内平均 RT 排在 TOP N 的 SQL:

obclient>SELECT/*+ PARALLEL(15)*/ SQL_ID, COUNT(*) AS QPS, AVG(t1.elapsed_time) RT                   FROM oceanbase.gv$sql_audit t1                   WHERE tenant_id = 1001 AND IS_EXECUTOR_RPC = 0                    AND request_time > (time_to_usec(now()) - 10000000)                       AND request_time < time_to_usec(now())                GROUP BY t1.sql_id ORDER BY RT DESC LIMIT 10;              +----------------------------------+------+------------+| SQL_ID                           | QPS  | RT         |+----------------------------------+------+------------+| 0A3D3DCB3343BBBB10E4B4B9777B77FC |    1 | 53618.0000 || A3831961C337545AF5BD1219BE29867A |    1 | 50764.0000 || F3DC5EF627DA63AE52044FCE7732267C |    1 | 48497.0000 || 39C63F143FDDACAEC090F480789DBCA5 |    1 | 47035.0000 || A3BF306B02FF86E76C96C9CEFADBDB7E |    1 | 45553.0000 || 7942E8D29BAFBF23EF3E3D29D55F428A |    1 | 45285.0000 || 20989A74CC1703664BDE9D6EA7830C24 |    1 | 39143.0000 || 80F40791E76C79D3DCD46FEEFFAB338E |    1 | 37654.0000 || 07E2FE351E3DD82843E81930B84D3DDE |    1 | 37231.0000 || 11B19DB5A1393590ABBE08005C155B2E |    1 | 37139.0000 |+----------------------------------+------+------------+

查询所有 SQL 中平均执行时间排在 TOP N 的 SQL

运行如下语句可以查询所有 SQL 中平均执行时间排在 TOP N 的 SQL:

obclient>SELECT/*+ PARALLEL(15)*/avg_exe_usec, svr_ip, svr_port, sql_id, plan_id                 FROM oceanbase.gv$plan_cache_plan_stat                 WHERE tenant_id = 1001                 ORDER BY avg_exe_usec DESC LIMIT 3\G;*************************** 1. row ***************************avg_exe_usec: 9795912      svr_ip: 10.183.76.140    svr_port: 2882      sql_id: C5D91E6C772D1B87C32BB3C9ED1435E1     plan_id: 4668689*************************** 2. row ***************************avg_exe_usec: 9435052      svr_ip: 10.103.229.107    svr_port: 2882      sql_id: 3B6EFEEC8332EB2A0822A3EA7B769500     plan_id: 4692858*************************** 3. row ***************************avg_exe_usec: 9335002      svr_ip: 11.180.113.7    svr_port: 2882      sql_id: 3B6EFEEC8332EB2A0822A3EA7B769500     plan_id: 4683085