注册

自定义find_in_set函数在可视化工具中执行成功,但是在disql中执行有误

马又虫 2021/12/06 1449 4 已解决

为提高效率,提问时请提供以下信息,问题描述清晰可优先响应。
【DM版本】:dm8
【操作系统】:uos
【CPU】:Kunpeng 920-5251K
【问题描述】*:在社区中找了mysql的Find_in_set的自定义函数,具体sql如下

CREATE OR REPLACE FUNCTION FIND_IN_SET
(
piv_str1 varchar2,
piv_str2 varchar2,
p_sep varchar2 := ‘,’)
RETURN NUMBER
IS
l_idx number:=0; – 用于计算piv_str2中分隔符的位置
str varchar2(500); – 根据分隔符截取的子字符串
piv_str varchar2(500) := piv_str2; – 将piv_str2赋值给piv_str
res number :=0; – 返回结果
loopIndex number :=0;
BEGIN
– 如果piv_str中没有分割符,直接判断piv_str1和piv_str是否相等,相等 res=1
IF instr(piv_str, p_sep, 1) = 0 THEN
IF piv_str = piv_str1 THEN
res := 1;
END IF;
ELSE
– 循环按分隔符截取piv_str
LOOP
l_idx := instr(piv_str, p_sep);
loopIndex:=loopIndex+1;
– 当piv_str中还有分隔符时
IF l_idx > 0 THEN
– 截取第一个分隔符前的字段str
str:= substr(piv_str, 1, l_idx-1);
– 判断 str 和piv_str1 是否相等,相等 res=1 并结束循环判断
IF str = piv_str1 THEN
res:= loopIndex;
EXIT;
END IF;
piv_str := substr(piv_str, l_idx+length(p_sep));
ELSE
– 当截取后的piv_str 中不存在分割符时,判断piv_str和piv_str1是否相等,相等 res=1
IF piv_str = piv_str1 THEN
res:= loopIndex;
END IF;
– 无论最后是否相等,都跳出循环
EXIT;
END IF;
END LOOP;
– 结束循环
END IF;
– 返回res
RETURN res;
END FIND_IN_SET;

我在DM管理工具中执行该sql成功
image.png

然后在uos系统中使用disql工具连接数据库后,执行该sql后无响应,改为执行sql文件脚本后,提示The script file is not complete,last sql has not been executed.
image.png

请问是什么地方有问题?

回答 0
暂无回答
扫一扫
联系客服