`

Hibernate自动建表

 
阅读更多

hibernate的自动建表功能可以给我们提供很大的便利,本人参考网络资料及编码实践整理如下

1:只要在hibernate.cfg.xml添加这句话,就可以自动生成数据表

<propertyname="hibernate.hbm2ddl.auto">update</property>

  update:表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列(并且表中原来的数据不会丢失)(注:若表里有多余的列,则不会删除)。若对应类型不一致,则不会修改表的字段的类型,操作(如插入记录)失败(Consle无错误提示)

还有其他的参数:

  create:启动hibernate时,自动删除原来的表,新建所有的表,所以每次启动后的以前数据都会丢失。

  create-drop:启动hibernate时,自动创建表,程序关闭时,自动把相应的表都删除。所以程序结束时,表和数据也不会再存在。

  validate:加载hibernate时,自动校验,如果表结构与实体类不一致,那么不做任何操作,报错;表不存在时也会报错

                  类型不一致时:例:Caused by:org.hibernate.HibernateException: Wrong column type in hibernate.people forcolumn file. Found: blob, expected: tinyblob

                  表不存在时:例:Caused by:org.hibernate.HibernateException: Missing table: people

 可设置<property name="hibernate.hbm2ddl.auto"value="none" />禁用该功能

2:编写一个方法,方法内容如下:

Configurationconf=new Configuration();

conf.configure("/hibernate.cfg.xml");

SchemaExportdbExport=new SchemaExport(conf);

dbExport.create(true,true);

上面两种方法虽然都能自动创建表。但需慎重使用。因为存在以下问题:

1:只能创建表不能创建数据库.

2:创建的表的数据类型、长度经常跟我们实际需要不符。(例如:对应于java的byte[],若不在<property>中指定length,自动生成的SQL类型为tinyblob,tinyblob若不能存放我们要存放的二进制数据,则向数据库中插入记录失败,虽然Consle中显示了insert语句,但没有插入记录,而且没有任何错误提示)

3:第一种方式每次执行都会把以前旧表删除再次创建新表,所以执行完毕后一般要把这个语句注释掉或删除。(否则会导致数据全部丢失!)

4:缺少初始化数据。

 

开发和部署建议:
在本机开发调试初始化数据的时候可以选择create、update等。
但是网站发布正式版本的时候,对数据库现有的数据或表结构进行自动的更新是很危险的。此时此刻应该由DBA同志通过手工的方式进行后台的数据库操作。
hibernate.hbm2ddl.auto的值建议是“none”或“validate”。“validate”应该是最好的选择:这样 spring在加载之初,如果model层和数据库表结构不同,就会报错,这样有助于技术运维预先发现问题。

分享到:
评论

相关推荐

    hibernate3.5多对多自动建表

    用hibernate3.5 xml文件映射,junit实现多对多自动建表,下载后解压用myeclipse导入,这里要注意:需要junit的包。这个是学hibernate的关键,建议新手作为重点,大虾就请多多指教了

    springMVC4+hibernate4+mysql全注解自动建表

    注释齐全,'零'配置文件 (1)在config中找到db.properties:连接自己的mysql (2)在连接到的mysql中建一个数据库(database):(defaultName:mvcdemo) (3)运行本项目 (4)页面输入 ...

    毕设-B2B 在线招标系统

    2.sql 见 src 目录下 sql 文件 , 默认 hibernate 自动建表 3.配置文件见 src/resources 目录 1.springMvc 以 location="classpath:*-gourderwa.properties" 装载配置,若修改配置文件名称对应修改此处 2.指定 ...

    HIBERNATE:Hibernate 学习一--注解方式自动建表

    NULL 博文链接:https://xiaojianhx.iteye.com/blog/1744681

    学生宿舍管理系统(struts2和hibernate)

    struts2和hibernate整合的,hibernate使用的注解方式,数据库是mysql。数据库的配置在hibernate.cfg.xml中修改一下,直接新建一个数据库就可以了,hibernate自动建表,自己手动在程序中添加数据信息。

    SSH高质量整合.Spring注解标签,项目启动自动建表.

    SSH高质量整合.Spring注解标签,项目启动自动建表. 标签注入,管理更简单 QQ95546772

    chepiao.zip_mvc 订票系统_订票

    网上订票系统,MVC框架,hibernate自动建表

    图书管理系统-JavaWeb版本

    ·Hibernate自动建表 应用功能: ·图书分类管理(增、删、改、查) ·图书管理(增、删、改、查) ·读者信息管理(增、删、改、查) ·前台图书查询 ·前台读者查询 ·前台外借查询 ·查询...

    酒店管理系统SSH框架整合

    酒店管理系统SSH框架整合,整合SSH框架,使用Hibernate自动建表,请下载下来解压之后,导入Eclipse中,修改数据库链接地址,必须先建库,数据库字符集要和链接字符串一致,否则无法自动建表

    SSH整合最全jar包即配置文件

    jar包全部都在,不少包,有hibernate自动建表语句,服务器用的Tomcat 7 jdk 1.7 eclipse 的 里面写了一个增加的功能,其他的你们可以自己改。 无压力跑起来。

    struts2+hibernate整合增删改查加注册登录Demo包含数据库自动建表语句

    简单地Struts2+hibernate的整合,包含了基本的增删改查,另外写了个登录和注册。可以试试,适合框架初学者。简单 jar包齐全。

    详解hibernate自动创建表的配置

    详解hibernate自动创建表的配置 配置自动创建表: ”hibernate.hbm2ddl.auto”&gt;update&lt;/prop&gt;//首次创建项目时用,项目稳定后一般注释这里有4个值: update:表示自动根据model对象来更新表结构,启动hibernate时会...

    spring-boot-test:springboot学习笔记!

    Springboot的学习记录 此代码库主要记录本人对Springboot的学习...引入Mysql数据库,引入Jpa管理数据库,使用Hibernate自动建表。 使用Jpa对数据库进行增加、删除、修改和查询,全部使用JpaRepository接口的方法实现

    自动在数据库中建成表(Hibernate)

    只要在实体类中写好属性,他就会自动在数据库中建成你所想要的表,很不错的奥,可以看下啊!!!

    解决 Springboot Jpa 自动创建表 和字段乱序问题[凤凰小哥哥]

    产生原因:因为使用 jpa 自动创建表的时候,采用的是TreeMap的,我们要变成LinkedHashMap 的结构。 解决方案:在项目下java文件夹下创建包名为: org.hibernate.cfg ,创建类: PropertyContainer [包名,类名...

    hibernate的相关jar包

    hibernate的相关jar,还有hibernate在控制台查看自动生成的建表语句的解决。

    ibatis和hibernate的区别

    ibatas的sql语句需要自己手动写,而...而hibernate还能够自动建表等等,这样的好处就在于你带着这个程序,无论到什么机器上,你都不需要数据库,应为它能自动为你完成,而ibatas就必须要有相应的数据库表才能进行移植

    Android数据库hibernate框架.

    自动建表,支持属性来自继承类:可根据注解自动完成建表,并且对于继承类中的注解字段也支持自动建表. 2.自动支持增删改 * ,增改支持对象化操作:增删改是数据库操作的最基本单元,不用重复写这些增删改的代码,并且添加...

    hibernate简单的入门案例

    hibernate简单的入门案例 ,使用mysql数据库,在配置文件中配置好相应的信息后,自动在mysql中创建表

    java模拟hibernate实现

    利用java反射和java注解实现JDBC封装,模拟hibernatez自动建表删表,实体关系映射,get,getAll,delete,update,add,事务处理等等。。

Global site tag (gtag.js) - Google Analytics