这是我在项目中所遇到的语法 随手记下来 希望对大家也会有所帮助
一、查当前数据库在执行的语句
select * from v$sessions where state=‘ACTIVE’
二、序号
mysql数据库用法:(@rownum:=@rownum+1) AS XH
达梦数据库用法: ROWNUM AS XH
三、SEPARATOR
mysql数据库用法:GROUP_CONCAT(b.LB SEPARATOR ‘换行’) as remark
达梦数据库用法:REPLACE(WM_CONCAT(b.LB) ,’,’,chr(10)) as remark
四、分组排序
mysql里的用法 group_concat(gkdxbm order by gkdxbm separator ‘换行’) as gkdxbm
达梦数据库用法 LISTAGG(gkdxbm, chr(10)) WITHIN GROUP (ORDER BY gkdxbm) AS gkdxbm
五、uuid
mysql中的uuid达梦数据库可以用guid和newid代替
六、convert
mysql里的用法:convert(type,value)
达梦数据库的用法:convert(value,type)
七、date
mysql中的date达梦数据库可以用 to_date代替
八、达梦数据库大写转小写LCASE
mysql里的用法:
select CONCAT(CONVERT(substr(‘000000000000000000000000000000000000’,1 ,(36 - LENGTH(REPLACE(newid() ,’-’ ,’’ )))) USING utf8 ) ,REPLACE(newid() ,’-’ ,’’ ) ) AS STM
达梦数据库的用法:
select LCASE(CONCAT(substr(‘000000000000000000000000000000000000’,1 ,(36 - LENGTH(REPLACE(newid() ,’-’ ,’’ )))), REPLACE(newid() ,’-’ ,’’ ))) AS STM
九、FIND_IN_SET
MySQL中的 FIND_IN_SET在达梦中可以自定义一个FIND_IN_SET函数来解决
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;

更多推荐