<p id="main-toc"><strong>目录</strong></p>
讯享网
1、概述
1.1 概述
1.2 实验环境
2、参数简介
3、实验部分
3.1 参数BLANK_PAD_MODE
3.2 参数COMPATIBLE_MODE
3.3 参数ORDER_BY_NULLS_FLAG
3.4 参数DATETIME_FMT_MODE
3.5 参数PL_SQLCODE_COMPATIBLE
3.6 参数CALC_AS_DECIMAL
3.7 参数ENABLE_PL_SYNONYM
3.8 参数VIEW_ACCESS_MODE
本文整理了达梦8数据库适配ORACLE的8个参数,设计了3个实验场景,通过实验观察各参数在数据库中的作用。
达梦数据库版本:DM Database 64 V8 0---20067
ORACLE版本:V19.3
1:表示将整数类型的除法、整数与字符或 BINARY 串的除法转换为 DECIMAL 处理;
2:表示将整数类型的除法、整数与字符或 BINARY 串的所有四则运算都转换为 DECIMAL 处理;
3:所有涉及整型的四则运算全部转换为 DECIMAL 处理。
注: 该 参 数 只有 在 USE_PLN_POOL 为 0 或 1 时有 效。 当 USE_PLN_POOL 为 2 或 3 时, 按 照CALC_AS_DECIMAL=2 处理 0 静态 1 ENABLE_PL_SYNONYM 是否可以通过同义词执行非系统用户创建的包或者存储过程。1是,0否。若设置为0,在解析过程/包名时,如果借助了同义词,则这些对象要么是系统内部创建的,或者其创建者必须为系统用户,否则一律报错 0 动态,系统级 1 VIEW_ACCESS_MODE 指定视图的自主访问控制机制。0:兼容 DM;1:兼容 ORACLE 0 静态 1
从oracle迁移数据到达梦数据库中,有时会遇到主键或唯一约束创建失败的情况,这有可能跟BLANK_PAD_MODE的设置有关,通常将BLANK_PAD_MODE设置为1可以解决问题。
测试方案说明:在表中插入3条数据,数据分别是字符串a、a加1个空格、a加两个空格。在ORACLE中这样的3条数据不被视为重复数据。在达梦8中,默认情况下视为重复数据,创建主键会报错。
1)在DM8中测试BLANK_PAD_MODE=0
准备测试数据
讯享网
测试是否能成功创建主键
测试结果:BLANK_PAD_MODE=0时,用案例数据创建主键失败。
2)在DM8中测试BLANK_PAD_MODE=1
BLANK_PAD_MODE是初始化参数,不能修改,我们创建个新库做下面的测试。
讯享网
启动新库
准备测试数据
讯享网
测试是否能成功创建主键

测试结果:BLANK_PAD_MODE=1时,用案例数据创建主键成功。
3)ORACLE中的相关测试
准备测试数据
讯享网
测试是否能成功创建主键

测试结果:ORACLE中用案例数据创建主键成功。
静态参数,修改后要重启数据库。
是否兼容其他数据库模式。0:不兼容,1:兼容 SQL92 标准,2:部分兼容 ORACLE,3:部分兼容 MS SQL SERVER,4:部分兼容 MYSQL,5:兼容 DM6,6:部分兼容 TERADATA,7:部分兼容 POSTGRES
这个参数是达梦数据库中最重要的兼容性参数,涉及内容较多,实验略。
动态,会话级参数:
控制排序时 NULL 值返回的位置,取值 0、1、2、3。
0 表示 NULL 值始终在最前面返回;
1 表示 ASC 升序排序时NULL 值在最后返回,DESC 降序排序时 NULL 值在最前面返回,在参数等于 1 的情况下,NULL 值的返回与 ORACLE保持一致;
1)在DM8中测试ORDER_BY_NULLS_FLAG=0
准备测试数据
讯享网
测试

测试结果:ORDER_BY_NULLS_FLAG=0时,NULL 值始终在最前面返回。

2)在DM8中测试ORDER_BY_NULLS_FLAG=1
动态参数,设置后立即生效
讯享网
准备测试数据
测试
讯享网

测试结果:ORDER_BY_NULLS_FLAG=1时,ASC 升序排序时NULL 值在最后返回,DESC 降序排序时 NULL 值在最前面返回。
3)在ORACLE中的相关测试
准备测试数据
测试
讯享网

测试结果:在ORACLE中, ASC升序排序时NULL 值在最后返回,DESC 降序排序时 NULL 值在最前面返回
动态系统级参数,是否兼容 ORACLE 的五种日期时间类型的默认日期时间格式。0:不兼容;1:兼容。 注:此参数被动态修改后仅影响新生成的会话
1)在DM8中测试DATETIME_FMT_MODE=0

日期格式为:YYYY-MM-DD
2)在DM8中测试DATETIME_FMT_MODE=1
动态系统级参数,不需要重启数据库
进入新会话测试

日期部分格式为:DD-MM月-YY
3)在ORACLE中的相关测试
在ORACLE中测试

日期格式为:DD-MM月-YY
静态参数,默认值为 0;如果设置为 1,则 PL 的异常处理中,SQLCODE 的错误码值需要尽量与 ORACLE 一致。
1)在DM8中测试PL_SQLCODE_COMPATIBLE=0
制造异常1,让系统抛出异常
讯享网

除0错误代码是-6103
制造异常2,做异常处理,查看SQLCODE的代码值

除0错误代码还是-6103
2)在DM8中测试PL_SQLCODE_COMPATIBLE=1
静态参数,需要重启数据库
讯享网
制造异常1,让系统抛出异常

虽然配置了兼容性参数PL_SQLCODE_COMPATIBLE=1,但是在系统抛出异常的场景中,除0错误码依然是-6103
制造异常2,做异常处理,查看SQLCODE的代码值
讯享网

测试结果:PL_SQLCODE_COMPATIBLE=1时,错误码发生了变化,现在是-1476
小结,通过上面的测试我们看到:
(1)系统抛出的异常代码不会去兼容ORACLE
(2)异常处理代码中的SQLCODE,可以配置成兼容ORACLE
3)在ORACLE中的相关测试
执行测试代码

Oracle除数为0的代码是1476

静态参数。
0:默认值,表示整数类型的除法、整数与字符或 BINARY 串的所有四则运算,结果都处理成整数;
1:表示将整数类型的除法、整数与字符或 BINARY 串的除法转换为 DECIMAL 处理;
2:表示将整数类型的除法、整数与字符或 BINARY 串的所有四则运算都转换为 DECIMAL 处理;
3:所有涉及整型的四则运算全部转换为 DECIMAL 处理。
注: 该 参 数 只有 在 USE_PLN_POOL 为 0 或 1 时有 效。 当 USE_PLN_POOL 为 2 或 3 时, 按 照CALC_AS_DECIMAL=2 处理
1)在DM8中测试CALC_AS_DECIMAL=0
执行测试代码
讯享网

小结:
1)这个参数适用于除数和被除数都是整数,具体可以观察实验中2/3与2.0/3的区别。
2)我们看到2/3的结果是0,而不是1,说明系统采用的是“舍位进位”而不是“四舍五入进位”。
2)在DM8中测试CALC_AS_DECIMAL=1
静态参数,配置后需要重启数据库生效
执行测试代码
讯享网

测试结果:除法的结果有小数部分了。
3)在ORACLE中的相关测试
执行测试代码

小结:通过实验我们发现,配置CALC_AS_DECIMAL=1后,达梦和ORACLE的小数位精度还是有一定差异的。
动态,系统级。是否可以通过同义词执行非系统用户创建的包或者存储过程。1是,0否。若设置为0,在解析过程/包名时,如果借助了同义词,则这些对象要么是系统内部创建的,或者其创建者必须为系统用户,否则一律报错
1)在DM8中测试ENABLE_PL_SYNONYM=0
创建非系统用户
讯享网
用新用户登录
创建存储过程
讯享网
创建同义词
执行存储过程
讯享网

用同义词执行存储过程

我们看到,ENABLE_PL_SYNONYM=0时,用同义词执行存储过程失败。
2)在DM8中测试ENABLE_PL_SYNONYM=1
动态参数,不需要重启
讯享网
调整完参数,再次测试用同义词执行非系统用户创建的存储过程

测试结果:ENABLE_PL_SYNONYM=1时,用同义词执行存储过程成功。
3)在ORACLE中的相关测试
在ORACLE中测试,准备:
讯享网
用同义词执行存储过程

测试结果:ORACLE中默认可以用同义词执行存储过程。
静态参数。
指定视图的自主访问控制机制。0:兼容 DM;1:兼容 ORACLE
实验部分待补充。(博主没有用过这个参数,有了解这个参数使用场景的欢迎在评论区留言)
本文结束!
参考文档:《DM8系统管理员手册》
2024年11月9日

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/159713.html