hibernate的hibernate.hbm2ddl.auto配置参数

10 篇文章 0 订阅

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

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时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值

 

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


原文地址:http://blog.csdn.net/leiswpu/article/details/6536588

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值