可以處理LOB欄位的常用字元函式
以前處理LOB欄位都是使用DBMS_LOB包,最近看了文件才發現,原來很多常用的字元函式都是支援LOB欄位的。
建立一個測試表:
SQL> CREATE TABLE T_LOB (ID NUMBER, CONTENTS CLOB);
Table created.
SQL> DECLARE
2 V_LOB CLOB;
3 BEGIN
4 INSERT INTO T_LOB
5 VALUES (1, EMPTY_CLOB())
6 RETURN CONTENTS INTO V_LOB;
7 FOR I IN 1..100 LOOP
8 DBMS_LOB.WRITEAPPEND(V_LOB, 32767, LPAD('A', 32767, 'A'));
9 END LOOP;
10 END;
11 /
PL/SQL procedure successfully completed.
SQL> SELECT ID, DBMS_LOB.GETLENGTH(CONTENTS) FROM T_LOB;
ID DBMS_LOB.GETLENGTH(CONTENTS)
---------- ----------------------------
1 3276700
SQL> SELECT ID, LENGTH(CONTENTS) FROM T_LOB;
ID LENGTH(CONTENTS)
---------- ----------------
1 3276700
這裡的LENGTH函式顯然不是對CLOB進行了隱式的TO_CHAR轉換,因為那樣的話,要不然因為CLOB長度太大而報錯,要不然CLOB自動擷取前4000個字元而LENGTH返回的長度則是4000。這裡的LENGTH函式明顯接收的是CLOB型別的引數。
除了LENGTH外,常用的INSTR、SUBSTR等都是支援LOB欄位的:
SQL> DECLARE
2 V_LOB CLOB;
3 BEGIN
4 SELECT CONTENTS
5 INTO V_LOB
6 FROM T_LOB
7 WHERE ID = 1
8 FOR UPDATE;
9 DBMS_LOB.WRITEAPPEND(V_LOB, 1000, RPAD('BCDEFG', 1000, 'A'));
10 COMMIT;
11 END;
12 /
PL/SQL procedure successfully completed.
SQL> SELECT DBMS_LOB.INSTR(CONTENTS, 'B')
2 FROM T_LOB
3 WHERE ID = 1;
DBMS_LOB.INSTR(CONTENTS,'B')
----------------------------
3276701
SQL> SELECT INSTR(CONTENTS, 'B')
2 FROM T_LOB
3 WHERE ID = 1;
INSTR(CONTENTS,'B')
-------------------
3276701
SQL> SELECT DBMS_LOB.SUBSTR(CONTENTS, 10, 3276701)
2 FROM T_LOB
3 WHERE ID = 1;
DBMS_LOB.SUBSTR(CONTENTS,10,3276701)
-------------------------------------------------------------------------------------------
BCDEFGAAAA
SQL> SELECT SUBSTR(CONTENTS, 3276701, 10)
2 FROM T_LOB
3 WHERE ID = 1;
SUBSTR(CONTENTS,3276701,10)
--------------------------------------------------------------------------------
BCDEFGAAAA
另外,LPAD、RPAD以及LTRIM和RTRIM也是支援CLOB型別的:
SQL> SELECT LTRIM(RTRIM(CONTENTS, 'A'), 'A')
2 FROM T_LOB
3 WHERE ID = 1;
LTRIM(RTRIM(CONTENTS,'A'),'A')
--------------------------------------------------------------------------------
BCDEFG
SQL> SELECT LENGTH(LPAD(CONTENTS, 10000000, 'B'))
2 FROM T_LOB
3 WHERE ID = 1;
LENGTH(LPAD(CONTENTS,10000000,'B'))
-----------------------------------
10000000
字元連線操作||也支援LOB型別:
SQL> SELECT LENGTH(CONTENTS || CONTENTS)
2 FROM T_LOB
3 WHERE ID = 1;
LENGTH(CONTENTS||CONTENTS)
--------------------------
6555400
如果想找更加詳細的支援LOB的函式說明可以參考LOB相關的文件。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4227/viewspace-664208/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- lob欄位的ora-1555處理方案
- 字元處理函式字元函式
- 一次PLSQL處理LOB欄位的優化SQL優化
- Oracle函式-->字元處理Oracle函式字元
- Mysql字元處理函式詳解MySql字元函式
- 欄位處理rtrim去掉結尾的特殊字元和空格字元
- MySql之json_extract函式處理json欄位MySqlJSON函式
- oracle中lob欄位Oracle
- MybatisPlus經典示例:使用Wrapper查詢指定欄位並新增欄位函式處理MyBatisAPP函式
- LOB欄位EMPTY_LOB和NULL的區別Null
- asp 中常用的檔案處理函式函式
- SQL中的常用的字串處理函式大全SQL字串函式
- 常用的圖象處理函式的整理 (轉)函式
- Matlab影像處理常用基本函式Matlab函式
- 處理PHP中字串的常用操作及函式PHP字串函式
- 【LOB】使用資料泵時 LOB 欄位存放位置
- ORACLE LOB大欄位維護Oracle
- 帶有LOB欄位的表遷移
- C++ 字元處理函式(cctype標頭檔案)C++字元函式
- JDBC處理包含CLOB欄位JDBC
- BLOB及CLOB欄位處理
- LOB欄位資料清理 - 更新為null後move lobNull
- Oracle 帶LOB欄位的表的遷移Oracle
- lob欄位表空間遷移
- iOS-GCD常用函式和柵欄函式iOSGC函式
- 釋放大資料量的lob欄位空間大資料
- 【函式】Oracle的常用字元函式實驗展示(一)函式Oracle字元
- 【函式】Oracle的常用字元函式實驗展示(二)函式Oracle字元
- Linux常用C函式—介面處理篇(轉)Linux函式
- NumPy常用的位運算函式函式
- PL/SQL 插入clob欄位處理SQL
- jquery註冊事件處理函式常用的幾種方式jQuery事件函式
- Oracle 建表時LOB欄位語法Oracle
- sql 統計多個欄位的和(如果欄位中含有 null 的處理)SQLNull
- 磁碟處理函式函式
- 資料處理之欄位合併
- oracle函式大全-字串處理函式Oracle函式字串
- pandas dataframe 時間欄位 diff 函式函式