WM_CONCAT函数主要用于将分组(GROUP BY)中的多个字符串值连接成一个由逗号分隔的字符串。虽然这个函数在某些Oracle版本中得到了广泛使用,但它并不是Oracle官方文档支持的函数,因此其未来的可用性和行为可能会发生变化。 指出Oracle 19c版本中WM_CONCAT的变化或替代方案: 在Oracle 19c及更高版本中,WM_CONCAT函数的...
conn wmsys/Pro_ut#19 --在wmsys下创建可用的wm_concat函数,直接执行以下语句 --定义类型 代码语言:javascript 复制 CREATEORREPLACETYPEWM_CONCAT_IMPLASOBJECT(CURR_STRVARCHAR2(32767),STATICFUNCTIONODCIAGGREGATEINITIALIZE(SCTXINOUTWM_CONCAT_IMPL)RETURNNUMBER,MEMBERFUNCTIONODCIAGGREGATEITERATE(SELFINOUTWM_CONCAT_...
在Oracle 19c中,wm_concat函数已被弃用,因此需要使用其他方法来替代。一种常用的替代方法是使用listagg函数。listagg函数可以将多个行的值连接成一个字符串,通过指定分隔符进行分隔。 以下是使用listagg函数替代wm_concat函数的示例: 假设有一个名为employees的表,其中包含employee_id和employee_name列。如果想要将所有员...
RETURN VARCHAR2 AGGREGATE USING WM_CONCAT_IMPL ; / --创建完成,给其创建同义词及授权,以供其他用户能正常使用。 create public synonym WM_CONCAT_IMPL for wmsys.WM_CONCAT_IMPL / create public synonym wm_concat for wmsys.wm_concat / grant execute on WM_CONCAT_IMPL to public / grant execute on ...
然而,很多应用程序在12c或19c中可能自定义了类似wm_concat的函数,例如 my_wm_concat。这些函数被广泛使用在应用程序中,当这些应用程序的数据库迁移到国产数据库如 MogDB 时,如果希望数据库层面兼容而不修改应用代码,我们就需要实现函数兼容。 在开源 PostgreSQL 版本中有string_agg函数实现类型功能,MogDB 中除了支持st...
SCTX2 IN WM_CONCAT_IMPL) RETURN NUMBER IS BEGIN IF(SCTX2.CURR_STR IS NOT NULL) THEN SELF.CURR_STR := SELF.CURR_STR || ',' || SCTX2.CURR_STR ; END IF; RETURN ODCICONST.SUCCESS; END; END; / CREATE OR REPLACE FUNCTION wm_concat(P1 VARCHAR2) ...
ORA-00904: "WM_CONCAT": invalid identifier 小结:如上所示,在19c中使用wm_concat函数,出现报错ora-00904.该函数在oracle 19c中不再支持. 当数据库从11g升到19c后,若该函数在代码中使用频率较高,改动代码不现实,此时就需要重新建立该函数. 2、处理步骤 ...
NUMBERISBEGINRETURNVALUE := CURR_STR ;RETURN ODCICONST.SUCCESS;END;MEMBER FUNCTION ODCIAGGREGATEMERGE(SELF IN OUT WM_CONCAT_IMPL,SCTX2 IN WM_CONCAT_IMPL)RETURN NUMBERISBEGINIF(SCTX2.CURR_STR IS NOT NULL) THENSELF.CURR_STR := SELF.CURR_STR || ',' || SCTX2.CURR_STR ;END IF;RETURN ...
下面介绍一下我的解决方法。首先分析一下,Oracle19C不兼容vm_concat列转行函数,并不代表其它函数不兼容,或许可以找到其它代替的,通过找资料,发现了Oracle11提供的另外一个函数:listagg()函数 语法:listagg(参数,‘分隔符’) within group(order by 参数id),验证可以实现在19C正常使用 ...
首先分析一下,Oracle19C不兼容vm_concat列转行函数,并不代表其它函数不兼容,或许可以找到其它代替的,通过找资料,发现了Oracle11提供的另外一个函数:listagg()函数 语法:listagg(参数,‘分隔符’) within group(order by 参数id),验证可以实现在19C正常使用 例如:to_char(wm_concat(t.busi_id...