查詢時LONG列追加資訊

yangtingkun發表於2010-06-19

ITPUB看到一個問題,如何在LONG欄位後新增其他內容。

原文來自:http://www.itpub.net/thread-886412-1-1.html

 

 

對於LONG列的限制非常多,因此直接在LONG後面透過||新增字串肯定是行不通的:

SQL> CREATE TABLE T_LONG
  2  (ID NUMBER,
  3  COL LONG);

Table created.

SQL> INSERT INTO T_LONG
  2  VALUES (1, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ');

1 row created.

SQL> COMMIT;

Commit complete.

SQL> SELECT COL || '1234' FROM T_LONG;
SELECT COL || '1234' FROM T_LONG
       *
ERROR at line 1:
ORA-00932: inconsistent datatypes: expected NUMBER got LONG

可以透過PL/SQL來實現這個功能,但是PL/SQL只能處理32K以內的LONG

最簡單的方法是透過LOB來過渡,LOB可以解決長度的問題,而且LONGLOB可以利用TO_LOB進行轉化,唯一的問題在於TO_LOB不能直接用在SELECT語句中,因此可以透過自治過程和臨時表實現:

SQL> CREATE GLOBAL TEMPORARY TABLE T_LONG_LOB
  2  (ID NUMBER,
  3  COL CLOB);

Table created.

SQL> CREATE OR REPLACE FUNCTION F_LONG(P_ID IN NUMBER) RETURN CLOB AS
  2     PRAGMA AUTONOMOUS_TRANSACTION;
  3     V_RESULT CLOB;
  4  BEGIN
  5     INSERT INTO T_LONG_LOB
  6     SELECT ID, TO_LOB(COL)
  7     FROM T_LONG
  8     WHERE ID = P_ID;
  9     SELECT COL || '1234'
 10     INTO V_RESULT
 11     FROM T_LONG_LOB
 12     WHERE ID = P_ID;
 13     COMMIT;
 14     RETURN V_RESULT;
 15  END;
 16  /

Function created.

SQL> SELECT F_LONG(ID) FROM T_LONG;

F_LONG(ID)
--------------------------------------------------------------------------------
ABCDEFGHIJKLMNOPQRSTUVWXYZ1234

 

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4227/viewspace-665705/,如需轉載,請註明出處,否則將追究法律責任。

相關文章