MySQL迁移DM8数据库注意事项

MySQL迁移DM8数据库注意事项

数据库安装时需要注意:

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

 

 

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

数据迁移工具:

 

数据管理工具:

 

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 则返回

    IF piv_str2 IS NULL THEN 

      RETURN res; 

    END IF; 

    -- 如果piv_str中没有分割符,直接判断piv_str1piv_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_strpiv_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(‘’)

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值