spring boot data jpa 手动指定数据库引擎

#spring boot data jpa 手动指定数据库引擎

首先需要说明的是,自己使用的Spring boot data jpa 的版本是2.1.6,版本不一样,可能会有所区别

项目中指定了 spring.jpa.generate-ddl=true,来指定自动生成DDL,这样在创建项目的时候,就会把相应的创建语句系统生成,对于自己写代码还是比较方便的(为了保证sql质量可控,一般项目都是设置为false),但是查看日志发现系统生成的表的engine 是MYISAM

网上查找资料说的是指定spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
然而指定了也没卵用,

最后经过排查

发现自己引用的base 模块中的application.properties中有使用这样的配置spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect,说明在配置中还是有一个优先级的区别的,后面会讲优先级的顺序

MySQL5Dialect 默认的就是使用MYISAM的引擎,所以把这里改成了MySQL5InnoDBDialect,确实就可以了,但是我是用的数据库的driver-class-name是com.mysql.cj.jdbc.Driver,那么我当然希望能够指定为Mysql8 的Dialect ,那就借助查看源码了,确实有一个MySQL8Dialect

但是当我查看MySQL5InnoDBDialect的源码的时候发现这个类是被@Deprecated,并且备注有这样的文字

Use “hibernate.dialect.storage_engine=innodb” environment variable or JVM system property instead.

但是其实你再application.properties中指定hibernate.dialect.storage_engine=innodb,是不会生效的,后来发现这里指定的是指在hibernate的环境中指定,所以应该是在hibernate.properties中指定hibernate.dialect.storage_engine=innodb, 如果使用这种方式的化,就知识指定数据库的引擎而已了

MySQLDialect的构造方法中有手动指定这样几行代码


                
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值