概述
在使用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!!!
最后
以上就是激昂背包为你收集整理的hibernate mysql 版本问题_Hibernate配置MySql出现的版本问题的全部内容,希望文章能够帮你解决hibernate mysql 版本问题_Hibernate配置MySql出现的版本问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复