#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
的构造方法中有手动指定这样几行代码