hibernate mysql 版本问题_Hibernate配置MySql出现的版本问题

在使用Hibernate配置MySQL5.6、5.7等版本时,遇到因SQL语法错误导致的异常。问题源于`type=InnoDB`在新版本MySQL中已不适用。解决方案是将Hibernate配置文件中的dialect从`org.hibernate.dialect.MySQLInnoDBDialect`改为`org.hibernate.dialect.MySQL5InnoDBDialect`,以适配新版本MySQL。
摘要由CSDN通过智能技术生成

在使用Hibernate配置MySql的时候,官方给出的示例是,是这么配置的:

表1org.hibernate.dialect.MySQLInnoDBDialect

而在配置的时候,我们往往还会给Hibernate添加一个更新策略:

表2update

这样一来,在运行程序的时候,就有可能会造成这样的一个异常信息:

表3Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:  You have an error in your SQL syntax; check the  manual that corresponds to your MySQL server version for the right syntax to  use near 'type=InnoDB'  at line 7

at  sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)

at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)

at  sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)

at  java.lang.reflect.Constructor.newInstance(Constructor.java:423)

at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)

at com.mysql.jdbc.Util.getInstance(Util.java:386)

at  com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1054)

at  com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4190)

at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4122)

at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2570)

at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2731)

at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2812)

at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2761)

at com.mysql.jdbc.StatementImpl.execute(StatementImpl.java:894)

at com.mysql.jdbc.StatementImpl.execute(StatementImpl.java:732)

at  org.hibernate.tool.schema.internal.exec.GenerationTargetToDatabase.accept(GenerationTargetToDatabase.java:54)

... 36 more

根据提示很显然得知:这是MySQL的版本问题导致的问题。

实际上,在MySQL5.0以前,type=InnoDB是有效的SQL语句,而现在,我们用的大多都是MySql5.6、MySQL5.7版本,type=InnoDB不再有效了。

解决办法就是修改hibernate.cfg.xml中的dialect属性,将

表4org.hibernate.dialect.MySQLInnoDBDialect

修改为:

表5org.hibernate.dialect.MySQL5InnoDBDialect

这是Hibernate中配置MySql所需要注意的一点!!!

END!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值