MySQL迁移DM8数据库注意事项
数据库安装时需要注意:
数据库安装后的常用工具:
数据库配置工具:兼容模式需设置为:4(兼容MySQL):
数据迁移工具:
数据管理工具:
SQL改造需要注意:
- MySQL中的“ ` ”无法使用,必须去除表名、字段名两端的“ ` ”
- 自增主键列无法插入主键,插入语句中不能存在主键列
- 历史数据中存在主表数据删除而关联表数据未删除的,添加自增数据时有可能会数据错误,如:
student表
id | name | gender |
50 | 王胜利 | 男 |
再MySQL若此表主键自增至100,但Id在50之后的数据均被删除,再添加数据时自增主键为101,但在迁移后的DM8中自增主键值为51。
student_class表
stu_id | 课程名 |
50 | 数学 |
51 | 数学 |
此表关联sutdent表,在Id为51的学生数据删除后数据{51,数学}本为无效数据,但在迁移后的DM8中添加了自增主键为51的数据后导致出现数据错乱。
解决办法:手动新增一条最大的数据即可
- union不支持 text、ntext 或 image 数据类型,用 convert(varchar(8000), 字段) as 字段替换即可。
- OR 和AND的优先级问题
MySQL中,AND的优先级高于OR,如果不写括号的情况下,OR默认只执行两边的条件。
eg:
SELECT * FROM table WHERE status = 1 AND state = 1 OR state=2
AND name = ‘xiaoming’
等同于
SELECT * FROM table WHERE status = 1 AND (state = 1 OR state=2)
AND name = ‘xiaoming’
在达梦数据库中较为特殊,OR优先级高于AND
eg:
SELECT * FROM table WHERE status = 1 AND state = 1 OR state=2
AND name = ‘xiaoming’
等同于
SELECT * FROM table WHERE (status = 1 AND state = 1) OR (state=2 AND name = ‘xiaoming’)
注意:虽然优先级不同,但是()的优先级都是最高,
因此,以后写sql时,将OR条件最好进行(),方便兼容,更方便阅读
- dm.jdbc.driver.DmdbNClob@466f461b情况:
有时候查询会出现的情况,考虑是长字段或所有字段总和过长引起的:
解决方案:
a、长字段单独查询;
b、使用left(字段,index)或 convert(varchar(8000),字段) AS 字段(推荐)
Eg:SELECT convert(varchar(8000),content_text) AS content_text FROM sys_article_system WHERE article_id = 1
函数改造:
函数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; -- 返回结果
res_place number:=0;-- 原字符串在目标字符串中的位置
BEGIN
-- 如果字段是null 则返回0
IF piv_str2 IS NULL THEN
RETURN res;
END IF;
-- 如果piv_str中没有分割符,直接判断piv_str1和piv_str是否相等,相等 res_place=1
IF instr(piv_str, p_sep, 1) = 0 THEN
IF piv_str = piv_str1 THEN
res_place:=1;
res:= res_place;
END IF;
ELSE
-- 循环按分隔符截取piv_str
LOOP
l_idx := instr(piv_str,p_sep);
--
res_place := res_place + 1;
-- 当piv_str中还有分隔符时
IF l_idx > 0 THEN
-- 截取第一个分隔符前的字段str
str:= substr(piv_str,1,l_idx-1);
-- 判断 str 和piv_str1 是否相等,相等则结束循环判断
IF str = piv_str1 THEN
res:= res_place;
EXIT;
END IF;
piv_str := substr(piv_str,l_idx+length(p_sep));
ELSE
-- 当截取后的piv_str 中不存在分割符时,判断piv_str和piv_str1是否相等,相等 res=res_path
IF piv_str = piv_str1 THEN
res:= res_place;
END IF;
-- 无论最后是否相等,都跳出循环
EXIT;
END IF;
END LOOP;
-- 结束循环
END IF;
-- 返回res
RETURN res;
END FIND_IN_SET;
函数GROUP_CONCAT代替方案:
WM_CONCAT(‘’)