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

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

相关推荐
科技小花21 分钟前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸22 分钟前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain24 分钟前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希1 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神1 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员1 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java1 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿2 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴2 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU2 小时前
三大范式和E-R图
数据库