hibernate的hibernate.hbm2ddl.auto配置参数
2013-11-20 10:45
316 查看
今天在生成并初始化数据库时,遇到以下错误:
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时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值
如果出现数据库表丢失的情况,可以检查该配置参数的设置
原文地址:/article/9231976.html
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时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值
如果出现数据库表丢失的情况,可以检查该配置参数的设置
原文地址:/article/9231976.html
相关文章推荐
- 视频专辑:JAVA语言入门视频教程
- javascript右下角弹层及自动隐藏
- Oracle分页查询
- 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第4章编程练习2
- java CopyOnWriteArrayList的使用
- ajax跨域访问数据接口 php
- List<>泛型排序,快速去重复
- Resin 配置(包括Eclipse集成)
- SCCM 2012 R2 从入门到精通 Part8 软件部署
- Mysql中EXISTS关键字用法、总结
- 视频专辑:网页平面设计-带你轻松掌握dreamweaver视频教程
- cloudera hadoop 安装问题
- 易景地球裁减影像数据的方法
- c++ primer敲代码第二章
- 模块化编程和AMD
- tomcat部署不正确
- CentOS6.4 RHCS
- 牛刀小试驱动_hello.ko
- Brief Intro to URL Handling of Foundation Framework (Examples: Downloading from a URL)
- 视频专辑:oeasy教你玩转office系列之PowerPoint ppt 视频教程