文章目录
- 总体介绍
- 注意事项(踩的坑)
总体介绍
- 武汉达梦数据库有限公司成立于2000年,为国有控股的基础软件企业,专业从事数据库管理系统研发、销售和服务。其前身是华中科技大学数据库与多媒体研究所,是国内最早从事数据库管理系统研发的科研机构。
- 达梦数据库管理系统是达梦公司推出的具有完全自主知识产权的高性能数据库管理系统,简称DM。目前应该已经到了8.0的版本,简称DM8。
- 本次适配达梦数据库为公司产品研发任务。由于科技战影响和国产数据库的发展,很多政府、军事、党群项目,新项目招标时都要求程序使用国产化数据库,达梦数据库是选项之一。
- 本次使用的达梦版本为最新版本,DM8,我们公司和达梦公司有直接的技术对接。
- 本次项目是java web 项目,使用Spring boot+ hibernate 5
注意事项(踩的坑)
- 在国产化数据库适配过程中,发现达梦和金仓遇到的好多问题都是类似或者完全相同的。可能是国产数据库开发中,采用的是类似的标准,因此部分问题高度相似。
- 必须针对数据库名称,建立用户名,赋予权限。否则即使设置default_schema,hibernate在执行原生的sql时也会报错
unkow jdbc driver : jdbc:dm;无效的表或视图名
。例如项目使用的数据库名project_oa
,则必须使用用户名为project_oa
连接。 - hibernate主键策略,
auto
默认到了sequence
,而不是identity
。 - 对现有数据库转库时,转库程序没有转换视图,视图需要手动添加
- 不支持
date_format
- 符号 ` 不支持
- 管理工具里创建视图界面 要拼上
as
,如果只是把SQL复制进去会报错的,前面加上as
即可。 - 我们原有数据库系统是MySQL,转库成达梦后,发现主键策略是
sequence
,但是手动创建hibernate_sequence
后,还是报错ERROR SqlExceptionHelper 仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值
,需要手动一个个去修改表结构主键设置,这样肯定不行的,已经将问题反馈给达梦,需要他们对方言包做适配,暂未解决 - 项目进行中,未完待续