达梦数据库适配遇到的一些问题

之前数据库国产化适配都是用的DM数据迁移工具做的,可以参考官方的迁移从 MySQL 移植到 DM,然后将迁移后的表和语句中程序运行时的报错解决了就可以了。

今天学习了一下达梦技术文档,手动创建了表空间,用户,数据库表,写入测试数据并用java进行连接进行了测试,发现了不少问题,记录一下。

一 springboot mybatis-plus 达梦依赖

mybatis-spring3.0 之后的版本才支持 DM 数据库

所以在引入mybatis-plus时要手动指定mybatis-spring的版本

xml 复制代码
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.14</version>
    <exclusions>
        <exclusion>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>3.0.5</version>
</dependency>
<dependency>
    <groupId>com.dameng</groupId>
    <artifactId>DmJdbcDriver18</artifactId>
    <version>8.1.3.140</version>
</dependency>

二 达梦数据库连接指定模式

每个用户有一个默认的同名的模式,访问自己模式下的表、视图等,不需要加模式名,访问其他模式下的对象需要拥有访问权限,访问时还需加上模式名。

所以在数据库连接时指定模式就不用在每个sql和表上加上模式名称了,具体的url配置如下?schema=后面的就是模式名

yml 复制代码
spring:
  datasource:
    url: jdbc:dm://127.0.0.1:5236?schema=ZBXT
    username: ZBXT
    password: Test@123456
    driver-class-name: dm.jdbc.driver.DmDriver

创建表空间,创建用户,指定模式语句(用SYSDBA执行)

sql 复制代码
CREATE TABLESPACE ZBXT DATAFILE 'zbxt.dbf' SIZE 128;
CREATE USER "ZBXT" IDENTIFIED BY "Test@123456" DEFAULT TABLESPACE "Test@123456";
GRANT DBA TO ZBXT;

三大小写问题和一些报错

如果你用达梦数据库自带的DM管理工具,你就会发现创建的表和字段全都是大写的,如果创建一些数据库保留关键字也是创建不起的,比如创建一个user表,DM管理工具的页面如图

如果你用官方推荐的SQLark百灵连接是可以创建成功的

我的建议是全部大写,小写的话后面会出现一些问题,我们接着看。

现在我们有两张表,一个ORG(全大写)一个user(全小写),属性都一样,id和name

我们创建两个java实体

java 复制代码
@Data
@TableName("org")
public class Org {
    @TableId(type = IdType.ASSIGN_UUID)
    private String id;
    private String name;
}

@Data
@TableName("\"user\"")
public class User {
    @TableId(type = IdType.ASSIGN_UUID)
    private String id;
    private String name;
}

对两个实体进行查询

ORG没问题,user会报错,一个是

复制代码
dm.jdbc.driver.DMException: 第 1 行, 第 42 列[user]附近出现错误: 
语法分析出错

我们对user表添加一个"user"

继续报错

复制代码
dm.jdbc.driver.DMException: 第1 行附近出现错误:
无效的列名[ID]

说user的ID无效,而且这里是大写的,我们给id也添加一个双引号"id", @TableField("\"ID\"")不管是大写还是小写的id都不行,我们把数据库的id改为大写试一下,其实DM管理工具改起来很方便,点击一下就自动变成大写了,而且用DM管理工具根本没法改成小写,这个就是在告诉们所有的名称都用大写。

数据库改成大写以后id字段就不报错了,而且java实体也不用指定@TableField了。

接下来就是name字段了,报错如下

复制代码
dm.jdbc.driver.DMException: 第1 行附近出现错误:
无效的列名[NAME]

其实我们java定义的时候是小写,转换的时候全都是大写了,我们就把name的数据库也改成大写就可以了,或者在name字段上添加 @TableField("\"name\"")

这时就不报错了

复制代码
==>  Preparing: SELECT id,"name" FROM "user"
==> Parameters: 
<==      Total: 0

但是这样改的地方就很多,最方便的还是把数据库的name字段改为大写NAME,这样我们只需要把一些数据库保留关键字和方言语法改一下就可以了。

一个建议

为了保持一致,建议所有的数据库表名和字段都改成大写。

项目示例代码

参考文献

https://eco.dameng.com/document/dm/zh-cn/app-dev/java_Mybatis_frame.html

相关推荐
猿小喵12 小时前
MySQL数据库源码调试
数据库·mysql
WangJunXiang612 小时前
Mysql数据库操作
数据库·mysql·oracle
2401_8589368812 小时前
51 单片机入门踩坑实录:从编译报错到数码管显示 1234 的完整解决
数据库
java1234_小锋12 小时前
Java高频面试题:Spring框架中的单例bean是线程安全的吗?
java·数据库·spring
代码探秘者12 小时前
【大模型应用】5.深入理解向量数据库
java·数据库·后端·python·spring·面试
2401_8320353412 小时前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python
roman_日积跬步-终至千里12 小时前
【论文ing】强化学习重塑 NL2SQL:单轮对齐、多轮交互与细粒度评估的最新进展(2020–2026)
数据库·sql·microsoft
杨超越luckly12 小时前
AI Agent应用指南 :自动化构建品牌数据库:提示词 + API + 结构化输出
大数据·数据库·人工智能·自动化·ai agent
写代码的小阿帆12 小时前
MySQL多表联查——内连、外连
数据库·mysql
九章-12 小时前
金仓数据库迁移工具链:Oracle平滑迁移的技术实践
数据库·oracle·数据库迁移工具·oracle迁移工具