hbm2ddl.auto设置为update时不能工作排查方法!

转载 2015年07月10日 09:40:48

问题描述:

在调试hibernate的时候发现设置hbm2ddl.auto设置为update是不能工作,eclipse中报如下错误:

Hibernate: insert into news (title, content) values (?, ?)
Exception in thread "main" org.hibernate.exception.SQLGrammarException: could not insert: [com.ericsson.ewanbao.News]
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:92)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)

...................

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'hibernate.news' doesn't exist
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)

...............


问题分析:

经检查数据库发现,news表确实创建不成功,可见hbm2ddl.auto设置为update没有能够建立表


解决步骤:

1.把mysql的general-log打开,这样可以跟踪所有的sql语句;

2.再次执行程序,在general-log的最后发现如下sql语句:

   3 Query  SHOW FULL TABLES FROM `hibernate` LIKE 'news'
   3 Query  create table news (id integer not null auto_increment, title varchar(255), content varchar(255), primary key (id)) type=InnoDB
   3 Query  SHOW FULL TABLES FROM `hibernate` LIKE 'PROBABLYNOT'
   3 Query  SET autocommit=0
   3 Query  SET autocommit=1
   3 Query  SET autocommit=0
   3 Query  insert into news (title, content) values ('???????', '???????????!')
   3 Query  SHOW FULL TABLES FROM `hibernate` LIKE 'PROBABLYNOT'

3.可以发现hibernate已经发送了见表语句给数据库,为什么建表没有成功了?尝试拷贝这些建表语句到sql控制台执行,得到如下结果:

mysql> create table news (id integer not null auto_increment, title varchar(255), content varchar(255), primary key (id)
) type=InnoDB;
ERROR 1064 (42000): 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 1

4.可以看到是sql语句错误,经分析发现是hibernate.dialect的设置错误,原先设置为org.hibernate.dialect.MySQLInnoDBDialect,应该修改为org.hibernate.dialect.MySQL5InnoDBDialect

Hibernate的hbm2ddl.auto=update的内幕

在使用Hibernate的时候我们一般都会配置hibernate.hbm2ddl.auto这个属性,而其中的常见的属性值包括: create create-drop validate update 而...

Hibernate不能自动建表解决办法

最近开始学Hibernate,看的是李刚的那本《轻量级java ee企业应用实战》。头一个hibernate程序,我原原本本的按照书上例子写下来,同时只是改动了些mysql的连接参数,并且在mysql...
  • biangren
  • biangren
  • 2012年09月23日 16:30
  • 34229

转] Hibernate不能自动建表解决办法(hibernate.hbm2ddl.auto) (tables doesn't exist)

转自: http://blog.csdn.net/biangren/article/details/8010018     最近开始学Hibernate,看的是李刚的那本《轻量级java ee企...

hibernate.hbm2ddl.auto为update无法自动建表

mysql5之前hibernate.dialect为org.hibernate.dialect.MySQLInnoDBDialect。 mysql5之后为org.hibernate.dialect....

hibernate.hbm2ddl.auto设置成update的问题

在 spring 与hibernate 结合时:  hibernate.hbm2ddl.auto有好几个设置值,其中就有update 这个值也是比较常用的,但是设置这个值可能会有一些问题出现。 所...

hibernate.hbm2ddl.auto 的设置

root jdbc:

hibernate.hbm2ddl.auto属性详解

  • 2013年04月15日 09:33
  • 553B
  • 下载

hibernate.hbm2ddl.auto配置详解

hibernate.cfg.xml 中hibernate.hbm2ddl.auto配置节点如下:      Hibernate Reference Documen...

Hibernate--hibernate.hbm2ddl.auto配置详解

com.mysql.jdbc.Driver jdbc:mysql://localhost:3306/hibernate root wuliang ...

hibernate.hbm2ddl.auto 配置项介绍

Hibernate部分配置项解析
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hbm2ddl.auto设置为update时不能工作排查方法!
举报原因:
原因补充:

(最多只允许输入30个字)