[20180926]神奇的規避ORA-01795方法.txt

来源:https://www.cnblogs.com/lfree/archive/2018/09/28/9720674.html
-Advertisement-
Play Games

[20180926]神奇的規避ORA-01795方法.txt--//大家知道in裡面的值限制1000個值,如果超出報ORA-01795錯誤.D:\> ooerr 0179501795, 00000, "maximum number of expressions in a list is 1000"D ...


[20180926]神奇的規避ORA-01795方法.txt

--//大家知道in裡面的值限制1000個值,如果超出報ORA-01795錯誤.

D:\> ooerr 01795
01795, 00000, "maximum number of expressions in a list is 1000"

D:\> oerr ora 01795
01795, 00000, "maximum number of expressions in a list is 1000"
// *Cause:    Number of expressions in the query exceeded than 1000.
//            Note that unused column/expressions are also counted
//            Maximum number of expressions that are allowed are 1000.
// *Action:   Reduce the number of expressions in the list and resubmit.

--//別人的awr報表我仔細查看,發現對方規避ora-01795的方法,使用集合的概念,仔細一想難道集合就沒有1000個的限制嗎?
--//我仔細看對方程式是寫死的,2000個集合,明顯這樣是沒有問題的.
--//有時候還是給佩服開發的想象力,我還是做一些例子說明問題.

1.環境:
SCOTT@test01p> @ ver1

PORT_STRING                    VERSION        BANNER                                                                               CON_ID
------------------------------ -------------- -------------------------------------------------------------------------------- ----------
IBMPC/WIN_NT64-9.1.0           12.1.0.1.0     Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production              0

SCOTT@test01p> create table t as select * from all_objects;
Table created.

SCOTT@test01p> create unique index i_t_object_id on t(object_id);
Index created.

--//分析表略.

2.測試1:
variable b1 number;
variable b2 number;
exec :b1 :=42;
exec :b2 :=47;

SCOTT@test01p> select * from t where (1,object_id) in ((1,:b1),(1,:b2));
OWNER OBJECT_NAME SUBOBJECT_NAME OBJECT_ID DATA_OBJECT_ID OBJECT_TYPE          CREATED             LAST_DDL_TIME       TIMESTAMP
----- ----------- -------------- --------- -------------- -------------------- ------------------- ------------------- -------------------
SYS   I_ICOL1                           42             42 INDEX                2013-06-28 09:03:29 2013-06-28 09:03:29 2013-06-28:09:03:29
SYS   I_USER2                           47             47 INDEX                2013-06-28 09:03:29 2013-06-28 09:03:29 2013-06-28:09:03:29

--//OK沒有問題,裡面僅僅包含2個集合,如果更多呢?

3.測試2:
select 'variable b'||to_char(level)||' number;' txt from dual connect by level<=1001
union all
select 'exec :b'||to_char(level)||' :='|| to_char(level) txt from dual connect by level<=1001
union all
select 'select * from t where (1,object_id) in (' txt from dual
union all
select '(1,:b'||to_char(level)||'),' txt from dual connect by level<=1000
union all
select '(1,:b'||to_char(1001)||'));' txt from dual ;

--//將輸出保存1個腳本,適當編輯執行.ok,沒有任何問題.執行計劃如下:
Plan hash value: 3525592940

----------------------------------------------------------------------------------------------------------------------------------------
| Id  | Operation                    | Name          | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time   | A-Rows |   A-Time   | Buffers |
----------------------------------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |               |      1 |        |       |   196 (100)|          |    891 |00:00:00.01 |      40 |
|   1 |  INLIST ITERATOR             |               |      1 |        |       |            |          |    891 |00:00:00.01 |      40 |
|   2 |   TABLE ACCESS BY INDEX ROWID| T             |   1001 |   1001 |   112K|   196   (0)| 00:00:01 |    891 |00:00:00.01 |      40 |
|*  3 |    INDEX UNIQUE SCAN         | I_T_OBJECT_ID |   1001 |   1001 |       |   178   (0)| 00:00:01 |    891 |00:00:00.01 |      22 |
----------------------------------------------------------------------------------------------------------------------------------------

--//1001個集合沒有任何問題.
--//修改b200-b999變數等於0,測試看看:
Plan hash value: 3525592940

----------------------------------------------------------------------------------------------------------------------------------------
| Id  | Operation                    | Name          | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time   | A-Rows |   A-Time   | Buffers |
----------------------------------------------------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |               |      1 |        |       |   196 (100)|          |    193 |00:00:00.01 |      16 |
|   1 |  INLIST ITERATOR             |               |      1 |        |       |            |          |    193 |00:00:00.01 |      16 |
|   2 |   TABLE ACCESS BY INDEX ROWID| T             |    203 |   1001 |   112K|   196   (0)| 00:00:01 |    193 |00:00:00.01 |      16 |
|*  3 |    INDEX UNIQUE SCAN         | I_T_OBJECT_ID |    203 |   1001 |       |   178   (0)| 00:00:01 |    193 |00:00:00.01 |      12 |
----------------------------------------------------------------------------------------------------------------------------------------

--//可以發現starts=203,重覆值不會掃描的.

4.我的估計:
--//對方2000個集合寫死的,我估計可能是一個數組,初始賦值0(或者查詢不到的值),然後賦值.
--//通過這樣的方式實現綁定變數.
--//我個人還是趨向這樣的方式使用臨時表更加合理簡單一些.


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 由於JDK是國際版的,我們在用javac編譯時,編譯程式首先會獲得我們操作系統預設採用的編碼格式(GBK),然後JDK就把Java源文件從GBK編碼格式轉換為Java內部預設的Unicode格式放入記憶體中,然後javac把轉換後的Unicode格式的文件編譯成class類文件。中文不支持Unicod ...
  • Linux搭建nfs服務 Linux教程 版權聲明:本文章參考了《鳥哥的Linux私房菜》、《Linux命令手冊》、《Linux命令大全》以及《Linux man pages》。未經作者允許,嚴禁用於商業出版,否則追究法律責任。網路轉載請註明出處,這是對原創者的起碼的尊重!!! 目錄 1 搭建服務端 ...
  • 1、統計 2017-10-25 16:30:00 至 2017-10-25 19:30:00 修改的文件的總大小 ...
  • MacBook讀寫不了NTFS,Windows也讀寫不了APFS和Mac OS 擴展分區,Ubuntu又用的是ext4分區,有時候想用U盤傳點東西真的費勁。著名公司Paragon Software開發了Apfs for Windows,很厲害了,就是太貴買不起。想來想去,買了一根網線,把這個問題解決 ...
  • 在win7電腦上使用遠程連接連接一臺伺服器時,出現發生身份驗證錯誤要求的函數不受支持的錯誤,原因是本地組策略配置錯誤,如下圖: 解決辦法: 進入windows命令行模式輸入命令: 會彈出本地策略組編輯器: 選擇:電腦配置>管理模板>系統>憑據分配>加密Oracle修正,如下圖: 選中後滑鼠右鍵進行 ...
  • 參考資料: https://docs.konghq.com/install/source/ 環境準備:操作系統 centeros7.3 1 :openssl和pcre一般系統自帶,如果沒有可自己安裝 https://www.openssl.org/source/ 或者 yum -y install ...
  • 摘要: 今天對物理數據表,進行增加列操作後,程式一直顯示無法找到相應列,通過仔細比對發現,視圖中無相應列更新,下文將具體的解決方法分享如下: 例: 轉自:http://www.maomao365.com/?p=7471 ...
  • 在拉薩藏民的客棧里,氣溫18度,碧藍的天空里大朵大朵飽滿的雲朵,耳機里放的陳鴻宇的民謠,下午五點正值陽光最佳,暖和和的氛圍里,有點小高反,所以這次,不寫技術博文,想寫下今年的一些人與事,刪減部分,留下職場部分。 如果轉載,請註明博文來源: www.cnblogs.com/xinysu/ ,版權歸 博 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...