• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
嘻哈•﹏•亻
博客园    首页    新随笔    联系   管理    订阅  订阅
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;

posted on 2021-03-15 10:49  嘻哈•﹏•亻  阅读(2333)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3