MySQL迁移DM8数据库注意事项

数据库安装时需要注意:

DM 工具 迁移到mysql dm迁移工具注意_数据库

数据库安装后的常用工具:

DM 工具 迁移到mysql dm迁移工具注意_DM 工具 迁移到mysql_02

 

 

数据库配置工具:兼容模式需设置为:4(兼容MySQL):

DM 工具 迁移到mysql dm迁移工具注意_字段_03

数据迁移工具:

DM 工具 迁移到mysql dm迁移工具注意_数据库_04

DM 工具 迁移到mysql dm迁移工具注意_DM 工具 迁移到mysql_05

DM 工具 迁移到mysql dm迁移工具注意_字段_06

DM 工具 迁移到mysql dm迁移工具注意_数据库_07

DM 工具 迁移到mysql dm迁移工具注意_DM 工具 迁移到mysql_08

 

数据管理工具:

DM 工具 迁移到mysql dm迁移工具注意_数据库_09

 

SQL改造需要注意:

  1. MySQL中的“ ` ”无法使用,必须去除表名、字段名两端的“ ` ”
  2. 自增主键列无法插入主键,插入语句中不能存在主键列
  3. 历史数据中存在主表数据删除而关联表数据未删除的,添加自增数据时有可能会数据错误,如:

student

id

name

gender

50

王胜利

再MySQL若此表主键自增至100,但Id在50之后的数据均被删除,再添加数据时自增主键为101,但在迁移后的DM8中自增主键值为51。

student_class

stu_id 

课程名

50

数学

51

数学

此表关联sutdent表,在Id为51的学生数据删除后数据{51,数学}本为无效数据,但在迁移后的DM8中添加了自增主键为51的数据后导致出现数据错乱。

解决办法:手动新增一条最大的数据即可

  1. union不支持 text、ntext 或 image 数据类型,用 convert(varchar(8000), 字段) as 字段替换即可。
  2. 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条件最好进行(),方便兼容,更方便阅读

  1. 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(‘’)