目录
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日
到此这篇达梦数据库连接池如何配置(达梦数据库连接数量设置)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/sjkxydsj/26588.html