真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何得到給定SQL的SQL_ID

本文參考蓋國強老師的博文進行測試。
作者:eygle |English 【轉(zhuǎn)載時請標(biāo)明出處和作者信息】|【恩墨學(xué)院 OCM培訓(xùn)傳DBA成功之道】
鏈接:http://www.eygle.com/archives/2017/08/dbms_sqltune_util0_sqltext_to_sqlid.html
-------------------------------------------------------------------------------------------------------------------

  1. 在 Oracle 數(shù)據(jù)庫中,如何得到給定SQL的 SQL_ID ? 這是曾經(jīng)被廣泛討論的一個問題。
  2. 現(xiàn)在,在Oracle 11g中,Oracle 給出了一個系統(tǒng)包,通過 dbms_sqltune_util0 可以簡便的計算出給定SQL的SQL_ID。

  3. SQL> desc dbms_sqltune_util0
  4. FUNCTION EXTRACT_BIND RETURNS SQL_BIND
  5.  Argument Name Type In/Out Default?
  6.  ------------------------------ ----------------------- ------ --------
  7.  BIND_DATA RAW IN
  8.  BIND_POS BINARY_INTEGER IN
  9. FUNCTION EXTRACT_BINDS RETURNS SQL_BIND_SET
  10.  Argument Name Type In/Out Default?
  11.  ------------------------------ ----------------------- ------ --------
  12.  BIND_DATA RAW IN
  13. FUNCTION GET_BINDS_COUNT RETURNS BINARY_INTEGER
  14.  Argument Name Type In/Out Default?
  15.  ------------------------------ ----------------------- ------ --------
  16.  BIND_DATA RAW IN
  17. FUNCTION IS_BIND_MASKED RETURNS NUMBER
  18.  Argument Name Type In/Out Default?
  19.  ------------------------------ ----------------------- ------ --------
  20.  BIND_POS BINARY_INTEGER IN
  21.  MASKED_BINDS_FLAG RAW IN DEFAULT
  22. FUNCTION SQLTEXT_TO_SIGNATURE RETURNS NUMBER
  23.  Argument Name Type In/Out Default?
  24.  ------------------------------ ----------------------- ------ --------
  25.  SQL_TEXT CLOB IN
  26.  FORCE_MATCH BINARY_INTEGER IN DEFAULT
  27. FUNCTION SQLTEXT_TO_SQLID RETURNS VARCHAR2
  28.  Argument Name Type In/Out Default?
  29.  ------------------------------ ----------------------- ------ --------
  30.  SQL_TEXT CLOB IN
  31. FUNCTION VALIDATE_SQLID RETURNS BINARY_INTEGER
  32.  Argument Name Type In/Out Default?
  33.  ------------------------------ ----------------------- ------ --------
  34.  SQL_ID VARCHAR2 IN

  35. 函數(shù) sqltext_to_sqlid 用于實現(xiàn)這個功能,以下測試使用了一個簡單的SQL查詢。
  36. 注意Oracle在SQL最后加入一個 chr(0) 的不可見字符,我們需要補齊:

  37. SYS@ r7>SELECT DBMS_SQLTUNE_UTIL0.SQLTEXT_TO_SQLID('SELECT SYSDATE FROM DUAL'||CHR(0)) SQL_ID FROM DUAL;

  38. SQL_ID
  39. ----------------------------------------------------------------------------------------------------------------------------------------------------------------
  40. c749bc43qqfz3
  41. 接下來看一下執(zhí)行這個查詢,數(shù)據(jù)庫中自動生成的SQL_ID,與通過函數(shù)轉(zhuǎn)換生成的完全一致:
  42. SYS@ r7>SELECT SYSDATE FROM DUAL;

  43. SYSDATE
  44. ---------
  45. 21-AUG-17

  46. SYS@ r7>SELECT SQL_ID FROM V$SQL WHERE SQL_TEXT='SELECT SYSDATE FROM DUAL';

  47. SQL_ID
  48. -------------
  49. c749bc43qqfz3

  50. 查看執(zhí)行計劃
  51. SYS@ r7>select * from table(dbms_xplan.display_cursor('c749bc43qqfz3'));

  52. PLAN_TABLE_OUTPUT
  53. ----------------------------------------------------------------------------------------------------------------------------------------------------------------
  54. SQL_ID c749bc43qqfz3, child number 0
  55. -------------------------------------
  56. SELECT SYSDATE FROM DUAL
  57. Plan hash value: 1388734953

  58. -----------------------------------------------------------------
  59. | Id | Operation | Name | Rows | Cost (%CPU)| Time |
  60. -----------------------------------------------------------------
  61. | 0 | SELECT STATEMENT | | | 2 (100)| |
  62. | 1 | FAST DUAL | | 1 | 2 (0)| 00:00:01 |
  63. -----------------------------------------------------------------

  64. 13 rows selected.


網(wǎng)頁標(biāo)題:如何得到給定SQL的SQL_ID
網(wǎng)頁路徑:http://weahome.cn/article/iesdhs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部