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

之前数据库国产化适配都是用的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 JSON_SET() 函数
数据库·mysql·json
山峰哥12 小时前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉13 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变13 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
山岚的运维笔记15 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里15 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科15 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦16 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
晚霞的不甘17 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位17 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全