解决SpringBoot2.0中的Hibernate针对MySQL5.7方言问题

参考:

mysql更改引擎(InnoDB,MyISAM)的方法_Mysql_脚本之家
https://www.jb51.net/article/57132.htm

该连接中提到mysql默认的数据库引擎是MyISAM,不支持事务和外键,也可使用支持事务和外键的InnoDB。

实际我通过HeidiSQL尝试,mysql5.7 默认使用的是 InnoDB, 查看MySQL配置文件my.ini配置也可以看到default-storage-engine=INNODB。

Springboot2.0中Hibernate默认创建的mysql表为myisam引擎问题 - tianyaleixiaowu的专栏 - CSDN博客
https://blog.csdn.net/tianyaleixiaowu/article/details/79468277

 

我使用SpringBoot2中的Hibernate,配置文件application.properties文件中配置的是spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect,效果是Hibernate使用的是MyISAM(通过HeidiSQL查看)。如果通过HeidiSQL手动建表,默认是InnoDB(查看MySQL配置文件my.ini配置也可以看到default-storage-engine=INNODB)。所以这里实际有个矛盾,就是MySQL5.7默认使用的引擎是InnoDB,而SpringBoot2.0中的Hibernate默认使用的是MyISAM。结合MySQL8已经放弃了MyISAM,另外MyISAM是非事务安全的,不支持外键,我选择修改Hibernate方言配置为InnoDB。

综上,如果想要采用InnoDB,就需要MySQL和Hibernate都做InnoDB相关的配置,由于MySQL5.7默认是InnoDB,所以只需要修改application.properties文件中的方言配置如下就行:

spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5InnoDBDialect

 

尊重原创,转载请注明出处:https://blog.csdn.net/Jerry_liu20080504/article/details/84874736

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值