国产数据库适配-达梦(DM)

本文详细介绍了达梦数据库管理系统的特点,包括其兼容性、高性能、高可用性和跨平台特性,以及与MySQL的差异,如函数支持和配置参数设置。指出在找不到对应MySQL函数时,可参考Oracle或联系厂商获取支持。
摘要由CSDN通过智能技术生成
1、通用性

达梦数据库管理系统兼容多种硬件体系,可运行于X86、X64、SPARC、POWER等硬件体系之上。DM各种平台上的数据存储结构和消息通信结构完全一致,使得DM各种组件在不同的硬件平台上具有一致的使用特性。
 达梦数据库管理系统产品实现了平台无关性,支持Windows系列、各版本Linux(2.4及2.4以上内核)、Unix、Kylin、AIX、Solaris等各种主流操作系统。达梦数据库的服务器、接口程序和管理工具均可在32位/64 位版本操作系统上使用。

2、高性能

支持列存储、数据压缩、物化视图等面向联机事务分析场景的优化选项;
 通过表级行存储、列存储选项技术,在同一产品中提供对联机事务处理和联机分析处理业务场景的支持;

3、高可用

可配置数据守护系统(主备),自动快速故障恢复,具有强大的容灾处理能力。

4、跨平台

跨平台,支持主流软硬件体系(支持windows、Linux、中标麒麟、银河麒麟等操作系统),支持主流标准接口。

5、高可扩展

支持拓展软件包和多种工具,实现海量数据分析处理、数据共享集群(DSC)和无共享数据库集群(MPP)等扩展功能

与MySQL的区别

1. 创建表的时候,不支持在列的后面直接加 comment 注释,使用 COMMENT ON  IS 代替,如:
   COMMENT ON TABLE xxx IS xxx
   COMMENT ON COLUMN xxx IS xxx
2. 不支持 date_sub 函数,使用 dateadd(datepart,n,date) 代替,

其中,datepart可以为:year(yy,yyyy)quarter(qq,q)month(mm,m)dayofyear(dy,y)day(dd,d)week(wk,ww)weekday(dw)hour(hh)minute(mi,n)second(ss,s), millisecond(ms)
  例子:

   select dateadd(month, -6, now());
   select dateadd(month, 2, now());
3. 不支持 date_format 函数,它有三种代替方法:

a: 使用 datepart 代替
语法:datepart(datepart, date),返回代表日期的指定部分的整数,
datepart可以为:year(yy,yyyy)quarter(qq,q)month(mm,m)dayofyear(dy,y)day(dd,d)week(wk,ww)weekday(dw)hour(hh)minute(mi,n)second(ss,s), millisecond(ms)
例子:

 select datepart(year, '2018-12-13 08:45:00'); --2018
 select datepart(month, '2018-12-13 08:45:00'); --12

b: 使用 date_part 代替
功能和 datepart 一样,写法不同,参数顺序颠倒,且都要加引号,
例子:

 select date_part('2018-12-13 08:45:00', 'year');--2018
 select date_part('2018-12-13 08:45:00', 'mm'); -- 12

c: 使用 extract 代替
语法:extract(dtfield from date),从日期类型date中抽取dtfield对应的值
dtfield 可以是 yearmonthdayhourminutesecond
例子:

  select extract(year from  '2018-12-13 08:45:00'); --2018
  select extract(month from  '2018-12-13 08:45:00'); --12
4. 不支持 substring_index 函数, 使用 substr / substring 代替,

语法:

    substr(char[,m[,n]])
    substring(char[from m[ for n]])
5. 不支持 group_concat 函数,使用 wm_concat 代替,

例子:

  select wm_concat(id) as idstr from persion ORDER BY id ;
6. 不支持 from_unixtime 函数,使用 round 代替

语法:

     round(date[,format])
7. 不支持 case-when-then-else ,

例如:

   select case  when id = 2 then "aaa" when id = 3 then "bbb" else "ccc" end as test
   from (select id from person) tt;
8. current_timestamp 的返回值带有时区,

例子:

     select current_timestamp(); --2018-12-17 14:34:18.433839 +08:00
9. convert(type, value) 函数,
与 mysql 的 convert 一样,但是参数是反过来的,mysql 是 convert(value, type)
10.  不支持 on duplicate key update,
     使用 merge into 代替 
11. 不支持 ignore,即 insert ignore  into
12. 不支持 replace into,
       使用 merge into 代替 
13. 不支持 if。
14.  不支持 "",只支持 ''
15. 不支持 auto_increment,
使用 identity 代替
如: identity(1, 1),从 1 开始,每次增 1 
16. 不支持 longtext 类型,
       可用 CLOB 代替。

配置参数

sf_set_system_para_value('COMPATIBLE_MODE',4,1,2); --兼容mysql,重启数据库生效
sf_set_system_para_value('GROUP_OPT_FLAG',3,1,2);--非兼容mysql情况下支持查询项不在分组函数中,重启数据库生效

这两个2选一,如果第一个没有问题,第二个就不需要执行了

sf_set_system_para_value('ENABLE_BLOB_CMP_FLAG',1,0,1);

总结

达梦数据库和 oracle 数据库比较像,如果找不到和 MySQL 对应的函数,可以看下 oracle 的相关函数。

它的使用文档可以在官网下载到。如果函数实在找不到而且项目里必须要用,可以找厂商提工单支持,他们反馈给开发,只不过周期稍微长点。

### 回答1: MyBatis-Plus支持达梦数据库,可以通过下面的示例来实现对达梦数据库适配:1. 在pom.xml文件中添加达梦数据库的驱动依赖: <dependency> <groupId>dm</groupId> <artifactId>dm-driver</artifactId> <version>7.7</version> </dependency>2. 在application.yml文件中配置达梦数据库的连接:spring: datasource: url: jdbc:dm://localhost:5236/test username: user password: 123456 driver-class-name: dm.jdbc.driver.DmDriver3. 在Mybatis-Plus的配置文件中添加对达梦数据库的自定义配置:mybatis-plus: configuration: dm: sql-injector: com.baomidou.mybatisplus.extension.injector.LogicSqlInjector4. 重新启动应用,MyBatis-Plus就可以正常使用达梦数据库了。 ### 回答2: MyBatis-Plus是一款优秀的持久层框架,它在MyBatis基础上进行了扩展和增强,提供了更为便捷的开发方式。 要适配达梦数据库,首先需要在项目的依赖管理中添加达梦数据库的驱动,可以通过Maven或Gradle下载并配置。 然后,在项目的配置文件中配置数据库连接信息,包括数据库类型、URL、用户名和密码等。 接下来,在项目中引入MyBatis-Plus的依赖,并配置相应的插件和拦截器,以支持MyBatis-Plus的特性和功能。可以使用@EnableMybatisPlus注解开启MyBatis-Plus的自动配置。 在编写数据访问层的代码时,可以使用MyBatis-Plus提供的通用Mapper接口和Wrapper查询构造器来实现便捷的数据库操作。通用Mapper接口提供了常见的增删改查方法,可以不再需要手动编写SQL语句,大大简化了开发工作。而Wrapper查询构造器提供了更为灵活的查询方式,可以进行复杂的条件查询。 此外,MyBatis-Plus还提供了代码生成器,可以根据数据库表结构自动生成实体类和Mapper接口的代码,极大地减少了手动创建的工作量。 综上所述,适配达梦数据库的示例主要包括添加数据库驱动、配置数据库连接信息、引入MyBatis-Plus依赖、配置插件和拦截器、使用通用Mapper接口和Wrapper查询构造器、以及使用代码生成器等步骤。通过这样的配置和操作,我们可以方便地使用MyBatis-Plus来操作达梦数据库,提高开发效率。 ### 回答3: MyBatis-Plus是一个在MyBatis基础之上进行扩展的数据库持久化框架,它提供了一系列的增强功能,简化了数据库操作的编写流程。但是,默认情况下,MyBatis-Plus并不支持达梦数据库,因为达梦数据库和其他主流数据库有一些不同之处。 要在MyBatis-Plus中适配达梦数据库,首先需要引入达梦数据库的相关的驱动包。可以下载达梦数据库官方提供的JDBC驱动包,并将其添加到项目的依赖中。 接着,在配置文件中,需要指定使用达梦数据库数据库方言。可以通过设置 `mybatis-plus.global-config.db-config.db-type` 属性来指定数据库方言为`dm`。 然后,需要配置数据源,指定连接达梦数据库的相关信息,比如数据库的URL、用户名和密码等。可以通过在配置文件中配置数据源相关的属性来完成这一步骤。 接下来,可以使用MyBatis-Plus提供的各种操作方法来进行数据库的增删改查等操作。MyBatis-Plus中的操作方法和MyBatis中的类似,只是在一些语法和使用上有一些不同,需要根据达梦数据库的特点进行相应的调整。 最后,根据实际需求进行一些其他的配置和优化。比如,可以通过配置文件中的属性来设置一些缓存策略、分页方言等。 总之,适配达梦数据库主要包括引入相关的驱动包、配置数据源、设置数据库方言和使用MyBatis-Plus的操作方法等步骤。通过这些步骤的完成,就可以在MyBatis-Plus中成功适配达梦数据库,并进行相应的数据库操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Memory_2020

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值