达梦(DM)报错[-3209]: 无效的存储参数

2024-04-09 02:44

本文主要是介绍达梦(DM)报错[-3209]: 无效的存储参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

@[TOC](达梦(DM)报错[-3209]: 无效的存储参数)

最近有一个项目,一直使用的是达梦数据库,今天遇到了一个问题,就是将测试环境新增加的表导入线上时报错 [-3209]: 无效的存储参数,这里我用我本地的达梦数据库复现一下这个问题,以及问题分析和解决方案。

问题复现

首先需要将达梦数据库测试环境新增加的表结构导出成sql语句,方便快速导入线上数据库,比如表:edu_face_train_apply_file

生成sql脚本

选中需要导出的新表edu_face_train_apply_file ,右键,选择【生成SQL脚本】-【Create To】-【文件】
在这里插入图片描述
选择存储sql脚本的文件目录后点击【保存】
在这里插入图片描述
这样新表的sql脚本就生成好了,下面我们开始拿生成的sql脚本导入到我自己本地的数据库复现出现的问题

问题复现

选中本地数据库链接,点击【新建查询】
在这里插入图片描述
点击工具栏【查询】,选择【执行脚本】
在这里插入图片描述
选中文件夹中刚才创建的sql脚本,点击【打开】
在这里插入图片描述
这时在本地数据库的查询窗口会看到生成一条导入的sql语句,同时执行sql脚本操作,这样我们就复现了问题
在这里插入图片描述

问题分析

出现这个问题的话,我们首先来看一下报错的位置,第16行有什么内容
在这里插入图片描述
再根据错误码 [-3209]: 无效的存储参数 在达梦官方文档中查询,可以看到官方文档中有这样问题的分析,
在这里插入图片描述
结合场景分析原因:初始化数据库实例的时候,有个大小写敏感的参数 CASE_SENSITIVE,要设置正确。
查询本地数据库的CASE_SENSITIVE

select SF_GET_CASE_SENSITIVE_FLAG();
-- 或者
select CASE_SENSITIVE();

执行结果,本地数据库大小写敏感
在这里插入图片描述
而测试环境库的大小写不敏感
在这里插入图片描述
因此才有这个问题,从大小写不敏感的数据库导出的sql脚本在大小写敏感的数据库上执行会有这样的问题。
大小写敏感的库,在 DM 默认都会转为大写,但是当用双引号引起来,如"hb_edu",则创建的对象名是小写的。上例中,创建的表空间名是大写的HB_EDU,所以,单独写 hb_edu会报这个对象不存在。如果创建的是大小写不敏感的库,则创建的对象名是小写就是小写,大写就是大写。

解决方案

那么我们按照官方文档中的描述来看,应是数据库大小写的问题,那么我们将sql脚本中的"hb_edu" 全部替换成大写"HB_EDU"尝试,如图
在这里插入图片描述
执行创建表的语句,执行成功
在这里插入图片描述
或者将"hb_edu"去掉双引号尝试,也可以执行成功
在这里插入图片描述
或者将"hb_edu"替换成 HB_EDU 尝试,也是可以执行成功的
在这里插入图片描述
当然,你也可以为了保证多个环境数据库大小写一致,更改大小写敏感参数

更改CASE_SENSITIVE

更改本地数据库CASE_SENSITIVE为大小写不敏感,通过函数

SP_SET_PARA_VALUE (scope int, paraname varchar(256), value bigint)
该过程用于修改整型静态配置参数和动态配置参数。SCOPE 参数为 0 表示修改内存中的动态配置参数值;参数为 1 表示修改内存和 INI 文件中的动态配置参数值;参数为 2 表示只在 INI 文件中修改配置参数,此时可修改静态配置参数和动态配置参数。当 SCOPE 等于 0 或 1,试图修改静态配置参数时服务器会返回错误信息。只有具有 DBA 角色的用户才有权限调用 SP_SET_PARA_VALUE。

我们可以设置SCOPE参数为1,直接修改内存和INI文件中的参数值,那么改完数据库大小写直接生效。
查询数据库CASE_SENSITIVE参数名

select * from v$option;
select * from v$option where PARA_NAME like '%CASE_SENSITIVE';

在这里插入图片描述
更改数据库参数GLOBAL_STR_CASE_SENSITIVE 为 0 大小写不敏感

SP_SET_PARA_VALUE (1, 'GLOBAL_STR_CASE_SENSITIVE', 0);

在这里插入图片描述
提示不可修改的话只能通过更改数据库配置文件dm.ini,但是操作数据库基础配置文件风险较大,因此还是采用上面的更改实例名成为"HB_EDU" 或者直接去掉双引号 hb_edu 这样就可以。

这篇关于达梦(DM)报错[-3209]: 无效的存储参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/886998

相关文章

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)

ABAP怎么把传入的参数刷新到内表里面呢?

1.在执行相关的功能操作之前,优先执行这一段代码,把输入的数据更新入内表里面 DATA: lo_guid TYPE REF TO cl_gui_alv_grid.CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'IMPORTINGe_grid = lo_guid.CALL METHOD lo_guid->check_changed_data.CALL M

yum install 失败报错`XZ_5.1.2alpha' not found (required by /lib64/librpmio.so.3)

/export/env/py3.6/lib/liblzma.so.5: version `XZ_5.1.2alpha' not found (required by /lib64/librpmio.so.3)   到/export/env/py3.6/lib cp /lib64/liblzma.so.5.2.2 . sudo ln -s -f liblzma.so.5.2.2 liblzm

Java面试八股之JVM参数-XX:+UseCompressedOops的作用

JVM参数-XX:+UseCompressedOops的作用 JVM参数-XX:+UseCompressedOops的作用是启用对象指针压缩(Ordinary Object Pointers compression)。这一特性主要应用于64位的Java虚拟机中,目的是为了减少内存使用。在传统的64位系统中,对象引用(即指针)通常占用8字节(64位),而大部分应用程序实际上并不需要如此大的地址空间

BD错误集锦6——【IDEA报错】tomcat server功能无效,报错Java EE: EJB, JPA, Servlets

在网上查找原因,发现是非法关闭IDEA导致的。 Open Settings | Plugns and enable it. 在设置中enable JAVA EE和tomcat server即可。 参考: https://stackoverflow.com/questions/43607642/intellij-idea-plugin-errorproblems-found-loadin

mysql中存储过过程和游标的联合使用

1.SQL如下: DELIMITER //DROP PROCEDURE IF EXISTS PrintAllEmployeeNames5;CREATE PROCEDURE PrintAllEmployeeNames5()BEGINDECLARE error_count INT DEFAULT 0;DECLARE num INT ;DECLARE done INT DEFAULT

关于命令行参数argv(《学习OpenCV》)

在《学习OpenCV》这本书中,很多示例代码都用到了命令行参数。作为新手,之前总是很困扰,不知道怎么用。偶然的机会终于略知一二了。 在Visual Studio中,我们可以自行设置命令行参数。 如在这个示例程序中,我们想把图像存入argv[1]。 方法如下: 依次点击,项目、属性、配置属性、调试、命令参数。出现下面的界面: 然后进行编辑,即输入图像路径。如:E:\Lena.jpg

ORACLE 、达梦 数据库查询指定库指定表的索引信息

在Oracle数据库中,索引是一种关键的性能优化工具,通过它可以加快数据检索速度。在本文中,我们将深入探讨如何详细查询指定表的索引信息,以及如何利用系统视图和SQL查询来获取这些信息。 索引在数据库中的重要性 索引是一种数据结构,用于加快数据库表中数据的检索速度。它类似于书籍的目录,可以帮助数据库引擎快速定位数据行,特别是在大型数据集合下,其作用尤为显著。 查询指定表的索引信息 在Orac

关于文章“python+百度语音识别+星火大模型+讯飞语音合成的语音助手”报错的修改

前言 关于我的文章:python+百度语音识别+星火大模型+讯飞语音合成的语音助手,运行不起来的问题 文章地址: https://blog.csdn.net/Phillip_xian/article/details/138195725?spm=1001.2014.3001.5501 1.报错问题 如果运行中报错,且报错位置在Xufi_Voice.py文件中的pcm_2_wav,如下图所示

pom.xml第一行报错

错误信息:org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project.MavenProject,org.apache.maven.archiver.MavenArchiveConfiguration)  解决办法:  Help–>Install From Site Connectivity(instal