hibernate的hibernate.hbm2ddl.auto配置参数

今天在生成并初始化数据库时,遇到以下错误:

Exception in thread "main" org.hibernate.exception.SQLGrammarException: could not execute query
    at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:90)
    at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
    at org.hibernate.loader.Loader.doList(Loader.java:2235)
    at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2129)

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

在网上查阅了半天,报这个异常可能有很多原因,但我这里是因为执行查询的时候对象表不存在造成的。我使用的spring+JPA+hibernate框架,在老大指引下,才发现hibernate的配置参数hibernate.hbm2ddl.auto=none,原来如此,当该参数设置为none时,框架无法自动生成表,因此才有前面找不到表的异常。现将该参数取值做一个总结:

1、create

如果设置为该值,则每次加载hibernate时(准确说应是创建SessionFactory时)都会删除以前创建的表而根据model重新生成表,即使前后的表没有任何变化,通常会造成数据库数据丢失,需谨慎使用这个取值

2、create-drop

与create差不多,所不同的是每次sessionFactory关闭时,就会删除所有表

3、update

这个取值比较常用,需要先建立数据库,在第一次加载hibernate时会自动创建表,以后创建hibernate会自动根据model更新表结构,即使表结构改变了,以前的行不会被删除

4、validate

每次加载hibernate时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值

 

如果出现数据库表丢失的情况,可以检查该配置参数的设置

你可能感兴趣的:(spring,Hibernate,数据库,exception,框架,jpa)