在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

怎么在Oracle12C数据库创建wm

219次阅读
没有评论

共计 2018 个字符,预计需要花费 6 分钟才能阅读完成。

本篇内容介绍了“怎么在 Oracle12C 数据库创建 wm_concat 函数”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

当我们的程序需要连接 12C 数据库时,原本使用 wm_concat 函数的地方会出现报错,这是由于 12C 已经摒弃了 wm_concat 这个函数,可以采取的办法有使用 listagg 函数代替 wm_concat 函数,但是程序中所有涉及 wm_concat 函数的地方都得改成 listagg 函数的写法,所以为了减小修改程序的工作量,可以通过手工创建 wm_concat 函数来解决这个问题。

一、用 sys 用户以 SYSDBA 身份登录数据库,执行以下命

CREATE OR REPLACE TYPE WM_CONCAT_IMPL AS OBJECT
-- AUTHID CURRENT_USER AS OBJECT
CURR_STR VARCHAR2(32767), 
STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL) RETURN NUMBER,
MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL,
P1 IN VARCHAR2) RETURN NUMBER,
MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN WM_CONCAT_IMPL,
RETURNVALUE OUT VARCHAR2,
FLAGS IN NUMBER)
RETURN NUMBER,
MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL,
SCTX2 IN WM_CONCAT_IMPL) RETURN NUMBER
/
-- 定义类型 body
CREATE OR REPLACE TYPE BODY WM_CONCAT_IMPL
STATIC FUNCTION ODCIAGGREGATEINITIALIZE(SCTX IN OUT WM_CONCAT_IMPL)
RETURN NUMBER
BEGIN
SCTX := WM_CONCAT_IMPL(NULL) ;
RETURN ODCICONST.SUCCESS;
MEMBER FUNCTION ODCIAGGREGATEITERATE(SELF IN OUT WM_CONCAT_IMPL,
P1 IN VARCHAR2)
RETURN NUMBER
BEGIN
IF(CURR_STR IS NOT NULL) THEN
CURR_STR := CURR_STR ||  ,  || P1;
CURR_STR := P1;
END IF;
RETURN ODCICONST.SUCCESS;
MEMBER FUNCTION ODCIAGGREGATETERMINATE(SELF IN WM_CONCAT_IMPL,
RETURNVALUE OUT VARCHAR2,
FLAGS IN NUMBER)
RETURN NUMBER
BEGIN
RETURNVALUE := CURR_STR ;
RETURN ODCICONST.SUCCESS;
MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL,
SCTX2 IN WM_CONCAT_IMPL)
RETURN NUMBER
BEGIN
IF(SCTX2.CURR_STR IS NOT NULL) THEN
SELF.CURR_STR := SELF.CURR_STR ||  ,  || SCTX2.CURR_STR ;
END IF;
RETURN ODCICONST.SUCCESS;
/
-- 自定义函数列表
CREATE OR REPLACE FUNCTION wm_concat(P1 VARCHAR2)
RETURN VARCHAR2 AGGREGATE USING WM_CONCAT_IMPL ;
/

二、创建同义词并授权

create public synonym WM_CONCAT_IMPL for sys.WM_CONCAT_IMPL
create public synonym wm_concat for sys.wm_concat
grant execute on WM_CONCAT_IMPL to public
grant execute on wm_concat to public
/

“怎么在 Oracle12C 数据库创建 wm_concat 函数”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-28发表,共计2018字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 国产精品精华液网站 | 性少妇中国内射xxxx狠干 | 2021国产成人精品国产 | 日韩在线欧美在线 | 四虎在线最新地址公告 | 久久免费观看视频 | 亚洲最大av资源站无码av网址 | 亚洲第一永久在线观看 | 不卡一区二区三区四区 | 亚洲国产日韩在线视频 | 伊人久久成人成综合网222 | 亚洲精品无码aⅴ中文字幕蜜桃 | www.91成人| 久久久久久久国产视频 | 99精品国产成人a∨免费看 | 熟妇人妻av无码一区二区三区 | 国产6080一级毛片 | 久草免费福利资源 | 国产精品视频网址 | 欧产日产国产精品精品 | 国产精品九九 | 成 人 免费观看网站 | 日本黄大片视频在线播放 | 一本色道久久88—综合亚洲精品 | 国产大片中文字幕在线观看 | 色综合久久中文娱乐网 | 亚洲第一福利视频 | 大肉大捧一进一出好爽视色大师 | 丰满少妇69激情啪啪无 | 肉体暴力强伦轩在线播放 | 伊人婷婷色香五月综合缴激情 | 四虎免费久久影院 | 老熟妇仑乱视频一区二区 | 午夜在线不卡精品国产 | 狠狠久久久久久亚洲综合网 | 欧美精品国产一区二区三区 | 韩国一级片 | 蜜臀色欲av在线播放国产日韩 | 久久久国产精品免费 | 国产区一区二区三 | 中文字幕久久亚洲一区 |