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

之前数据库国产化适配都是用的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

相关推荐
Tongpao_SSDHDD11 分钟前
希捷酷鹰ST6000VX008实测解析:中小安防监控高性价比存储方案
大数据·数据库·人工智能
蓝鸟197425 分钟前
Oracle超大DMP备份文件瘦身、日志精简、磁盘空间优化实战方案日志
数据库·oracle·数据库运维·生产运维实战·oracle避坑·磁盘空间优化·oracle日志清理
金融支付架构实战指南38 分钟前
CQRS + 命令模式 + 事件驱动 + 数据库持久化
数据库·ddd·命令模式·领域驱动模型
sevenll071 小时前
DocKit agentic MongoDB GUI 客户端 - 用自然语言和你的数据对话
数据库·mongodb·nosql·agent·桌面客户端
团象科技1 小时前
从一线实操案例拆解不同出海团队落地海外VPS运维独立站的路径细节
大数据·数据库·人工智能
小马爱打代码1 小时前
框架 - 组件 - 中间件:生产级参数配置指引
数据库·中间件
asdfg12589632 小时前
一文通俗理解JDBC中的核心概念+案例
java·数据库·oracle·jdbc
点灯小铭2 小时前
基于单片机与DAC0832的双路波形信号发生系统设计
数据库·单片机·mongodb·毕业设计·课程设计·期末大作业
小陈phd2 小时前
Text2SQL智能体学习笔记(二)——NL2SQL落地的隐形基石:元数据库
数据库·笔记·学习
霸道流氓气质2 小时前
阿里云 OSS 从零到实战:概念、配置与 Spring Boot 集成指南
数据库·spring boot·阿里云