怎么在Oracle12C数据库创建wm

68次阅读
没有评论

共计 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字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)