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

 
 

你可能感兴趣的:(springboot,框架,Spring,data,jpa,MySQLDialect,hibernate,spring,boot)