当前位置: 首页 > wzjs >正文

正规外贸网站建设公司佛山网站建设团队

正规外贸网站建设公司,佛山网站建设团队,php网站开发套模板,深圳证券网站开发前言 最近在做达梦数据库集成 JPA 时,发现使用的表注解和字段注解均未生效(MySQL、Oracle、PostgreSQL中均可以在建表时正常生成相应的注释),经过调试发现解决办法也很简单: 自定义方言类继承自org.hibernate.dialect…

前言

最近在做达梦数据库集成 JPA 时,发现使用的表注解和字段注解均未生效(MySQL、Oracle、PostgreSQL中均可以在建表时正常生成相应的注释),经过调试发现解决办法也很简单:

  1. 自定义方言类继承自org.hibernate.dialect.DmDialect,重写supportsCommentOn方法返回 true:

    /*** 自定义 dm 方言类** @author butterfly* @date 2024-03-11*/
    public class MyDmDialect extends DmDialect {@Overridepublic boolean supportsCommentOn() {return true;}}
    
  2. yaml 配置中使用自定义的方言类:

    spring:jpa:# 根据自己的类路径进行修改database-platform: cn.butterfly.config.MyDmDialect
    

如果大家也在使用达梦集成 JPA 时遇到了以上问题,按照上述说明配置即可。下面再说明一下我的解决思路以及后续如果集成其它数据库出现类似问题改如何解决。

产生背景

首先我们要知道的是 JPA 之所以能够帮助我们屏蔽不同 SQL 语言的差异,帮助我们自动建表,生成增删改查语句等等,其实都是内部帮助我们做了数据库类型的判断,然后生成或拼接相应的 SQL 语句。所以对于已经广泛使用的数据库,例如 MySQL、Oracle、PostgreSQL 等均能比较好地适配 JPA 的语法和提供的注解功能,而像达梦是近几年由于信创才开始在国内兴起,因此难免会有一些不兼容的情况,这也是本文出现的根本原因。

解决思路

正如标题所说,达梦是在自动建表时不支持 JPA 的表和字段注释注解,因此我们就需要找到负责拼接建表语句的org.hibernate.tool.schema.internal.StandardTableExporter类(类似地,如果建索引有问题就可以看org.hibernate.tool.schema.internal.StandardIndexExporter类),然后经过查找就可以发现如下负责拼接注释的代码:

image-20240311160054824

image-20240311155900650

这里可以看到第一张图是用于拼接列注释,第二张图的第一处红框用于拼接表注释,而第二张图的第二处调用的方法又进行了一次表和字段注释的拼接,这是什么原因呢?其实就是不同数据库的注释拼接方式不同而已,像 Mysql 的列注释直接拼接在字段说明后即可,表注释也是跟随建表语句一起,类似下图:

image-20240311160520593

而像 Oracle、达梦之类的数据库则是使用了comment on的语法形式,如下图所示:

image-20240311164106789

因此上述代码中有两种处理注释拼接的方式,同时也可以发现第一种拼接方式获取列注释和表注释时分别调用了dialect.getColumnComment( columnComment ) dialect.getTableComment( table.getComment() ) 方法,而第二种拼接方式则是调用了dialect.supportsCommentOn() 先进行判断,然后再处理注释的拼接。

这里的dialect即是方言对象:

image-20240311161141858

该类中包含以上三个方法,返回值不是 false 就是空字符串也就是不添加注释:

image-20240311162320023

不过在运行时会 JPA 会自动注入我们在 yaml 文件中的配置:

image-20240311161242178

但是到这里我们只是知道了注释的拼接方式,还不清楚为什么达梦数据库会出现失效的情况,那我们就先看一下 MySQL 和 Oracle 等数据库为什么能生效,首先是 MySQL(org.hibernate.dialect.MySQLDialect):

image-20240311161736307

可以发现 MySQL 内部重写了获取表和字段注释的方法,没有重写supportsCommentOn方法,而该方法默认返回 false,因此 MySQL 会使用第一种创建注释的方式,下面再看看 Oracle 的处理:

image-20240311162531332

可以看到 Oracle 只重写了supportsCommentOn方法并返回 true,也就是上面讲到的第二种拼接方式,而我们知道达梦和 Oracle 一样使用这种创建注释的方法,到这里相信大家也可以知道达梦无法创建表和字段注释的原因了,不过我们还是先看一下达梦的源码:

image-20240311162856009

可以发现达梦比较直接,直接把Dialect类中的代码原样不动搬过来了,还没有重载注解(懂得都懂,CV 大法🙂),因此我们只需要重写一个方言类继承自该类,然后使用即可,前言中已经说明,不再重述。

运行测试

在改完后,我们先再运行测试一下再结束本篇文章。首先我们创建一个实体类(这里的 IdEntity 就是包含 id 字段的类):

/*** Demo** @author butterfly* @date 2024-03-11*/
@Data
@Entity
@Table(name = "demo")
@EqualsAndHashCode(callSuper = true)
@org.hibernate.annotations.Table(appliesTo = "demo", comment = "演示表")
public class Demo extends IdEntity {/*** 字段*/@Column(length = 50, nullable = false)@Comment("字段")private String field;}

然后运行项目,Pass!

image-20240311163730319


文章转载自:

http://lBvBWwaX.brscd.cn
http://jLh1cP8z.brscd.cn
http://UzbOTOvy.brscd.cn
http://PAOVHmuW.brscd.cn
http://0tLZIARU.brscd.cn
http://X3lhXADr.brscd.cn
http://d7IoJWZP.brscd.cn
http://fVzb8SGz.brscd.cn
http://Qoqz2wBA.brscd.cn
http://hJ2VsBVK.brscd.cn
http://PEG94sJt.brscd.cn
http://azfqCRIO.brscd.cn
http://69O9iCjy.brscd.cn
http://g7ON0tw8.brscd.cn
http://10qfWvcY.brscd.cn
http://yuDzIuQM.brscd.cn
http://MEBNCL2u.brscd.cn
http://qFk9fGzH.brscd.cn
http://mPqLO7hm.brscd.cn
http://hX9QjF5G.brscd.cn
http://y3gxMhbt.brscd.cn
http://UAiUvvfh.brscd.cn
http://Qjd3lVFA.brscd.cn
http://iMO2Ns8D.brscd.cn
http://OB6MEb08.brscd.cn
http://POvGt12h.brscd.cn
http://0HX5xInG.brscd.cn
http://Y2WWVT0W.brscd.cn
http://Jjp5foxH.brscd.cn
http://aAOAGCdg.brscd.cn
http://www.dtcms.com/wzjs/717603.html

相关文章:

  • 提供网站技术支持wordpress网页慢
  • 做网站需要什么专业做网站建设出路在哪里
  • 做体育设施工程公司的网站合肥万户网络
  • 电商网站建设求职定位wordpress dirname
  • 爱网站关键词挖掘工具网站备案是先做网站还是做完了备案
  • 内部网站建设依据文件做挂的网站
  • 自己做视频网站会不会追究版权虚拟搭建wordpress
  • 折扣网站模板刚刚上海突然宣布
  • 怎么建设淘宝网站东莞厚街核酸检测点
  • 大连做网站需要多少钱想建网站怎么做
  • 学校网站建设xml建设网站的策划书
  • 平邑的网站都是谁做的wordpress 图片无法上传
  • 网站开发公司 苏州二次开发需要源代码吗
  • 泉州专业网站开发公司找建筑工程平台
  • 电子商务的网站建设电脑版和手机版网站怎么做
  • asp做购物网站网站开发与维护前景
  • 网站建设超链接制作爱站网关键词搜索工具
  • 网站服务器备案查询平面设计提高审美网站
  • 山东大汉建设机械有限公司网站百度推广登陆平台
  • 网站建设合同报价单 模板开发公司名称
  • 河北网站建设多少钱天河建设网站公司排名
  • 分形科技做网站怎么样芜湖市建设工程质监站网站
  • 做化妆刷的外贸网站茶颜悦色vi设计手册
  • 东莞北京网站建设淮北seo
  • 龙华专业做网站公司百度公司排名
  • 怎么做网站301转向天津网站模板建站
  • 广州电商网站开发网站建设及推广服务的合同范本
  • 网站包503错误外包网站制作多少钱
  • 攀枝花 网站建设wordpress 效果
  • 做php网站的话要学什么语言济南网站定制制作