Oracle Long類型數據轉換varchar


Oracle Long類型數據轉換varchar

之前即時通訊項目中消息字段是Long類型,通過查找相關資料寫的一個函數。

CREATE OR REPLACE FUNCTION LONG_TO_CHAR(in_rowid      rowid, --rowid
                                        in_owner      varchar, --所有者   可空
                                        in_table_name varchar, --表名
                                        in_column     varchar2 --要查詢的列名
                                        ) RETURN varchar AS
  text_c1 varchar2(32767);
  sql_cur varchar2(2000);
begin
  if length(in_owner) > 0 then
    sql_cur := 'select ' || in_column || ' from ' || in_owner || '.' ||
               in_table_name || ' where rowid = ' || chr(39) || in_rowid ||
               chr(39);
  else
    sql_cur := 'select ' || in_column || ' from ' || in_table_name ||
               ' where rowid =' || chr(39) || in_rowid || chr(39);
  end if;
  dbms_output.put_line(sql_cur);
  execute immediate sql_cur
    into text_c1;

  text_c1 := substr(text_c1, 1, 4000);
  RETURN TEXT_C1;
END;

用例:select b.remark,LONG_TO_CHAR(b.rowid, null, text , 'remark')from text b;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM