hibernate的hibernate.hbm2ddl.auto配置参数
来源:互联网 发布:淘宝客服怎么返现 编辑:程序博客网 时间:2024/04/28 15:10
今天在生成并初始化数据库时,遇到以下错误:
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时,验证创建数据库表结构,只会和数据库中的表进行比较,不会创建新表,但是会插入新值
如果出现数据库表丢失的情况,可以检查该配置参数的设置
- hibernate的hibernate.hbm2ddl.auto配置参数
- hibernate的hibernate.hbm2ddl.auto配置参数
- 【Hibernate】hbm2ddl.auto 参数的配置
- Hibernate一个配置参数hibernate.hbm2ddl.auto
- Hibernate一个配置参数hibernate.hbm2ddl.auto
- 【hibernate】 hbm2ddl.auto参数
- hibernate.hbm2ddl.auto配置
- hibernate.hbm2ddl.auto配置
- hibernate.hbm2ddl.auto配置
- 配置参数hibernate.hbm2ddl.auto 各个取值的含义
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- Hibernate配置文件中hiberante.hbm2ddl.auto四个参数的配置
- 关于hibernateProperties配置中hibernate.hbm2ddl.auto参数的作用
- 中小软件企业如何生存和发展
- linux 下strftime()的用法
- FileUpload上传多文件时出现“无法访问已关闭的文件”错误的解决方法
- 免费杀毒软件如何生存?
- 001. EsayUI系列之easyui-window
- hibernate的hibernate.hbm2ddl.auto配置参数
- ExtJs_ExtBoxComponent类解说
- 追MM与Java的23种设计模式
- Extjs Column布局常见问题及解决方法
- Q:若需要开发支持32bit与64bit的驱动程序,两者同时购买价格是否有优惠?
- 用sourceinsight看ns2源码 - [NS2]
- java1.5新特性之可变长参数
- 使用DLL在进程间共享数据
- UiModeManager设置夜间模式和行车模式