`

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层和数据库表结构不同,就会报错,这样有助于技术运维预先发现问题。

分享到:
评论

相关推荐

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

    使用Hibernate自动建表功能,可以快速地将设计的实体模型转化为实际的数据库结构,对于快速开发和原型验证非常有帮助。同时,也要注意,虽然自动建表方便,但在生产环境中应谨慎使用,以防止数据丢失。

    Hibernate动态建表

    5. **自动建表(Schema Generation)**: Hibernate的`hibernate.hbm2ddl.auto`配置属性决定了在应用启动时如何处理数据库表。设置为`create`会在每次启动时清空并重建表,`update`则只更新表结构以适应新的实体定义...

    hibernate3.5多对多自动建表

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

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

    通过这些注解和配置,开发者可以快速地建立Java对象与数据库表之间的映射,并利用Hibernate自动创建数据库表,大大提高了开发效率。在实际项目中,结合Spring等框架,可以实现更高效、便捷的数据库操作。 在提供的...

    hibernate根据类生成表

    1. Hibernate自动建表原理 Hibernate的核心是XML配置文件(hibernate.cfg.xml)和实体类。当我们指定了`hibernate.hbm2ddl.auto`属性为`create`或`update`时,Hibernate在启动时会自动检查数据库,如果不存在对应的...

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

    综上所述,SSH高质量整合利用Spring的注解简化配置,通过Hibernate的注解实现ORM映射,同时利用Hibernate的自动建表功能,极大地提高了开发效率。项目中的标签注入则优化了视图层的开发,使得整个Web应用的开发流程...

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

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

    JPA注解 和hibernate 建表

    JPA注解和Hibernate建表 一、JPA概述 Java Persistence API(JPA)是Sun官方提出的Java持久化规范,它只是一个规范不是一个产品。JPA的主要目标是提供一种简洁、易用的方式来访问、操作和管理Java应用程序中的数据...

    毕设-B2B 在线招标系统

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

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

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

    Hibernate自动生成表demo

    总的来说,通过使用Hibernate的注解和自动建表功能,我们可以轻松地在Java应用中建立数据库模型,并在运行时自动创建数据库表。这极大地提高了开发效率,降低了出错的可能性,并使得数据库与Java代码之间的关系更加...

    图书管理系统-JavaWeb版本

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

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

    3. **数据库自动建表语句**:在Hibernate中,可以通过配置使其自动根据映射文件创建数据库表,这对于快速原型开发或测试非常有用。这通常在hibernate.cfg.xml的`hibernate.hbm2ddl.auto`属性中设置,如设为"create...

    hibernate动态生成表结构

    在这种情况下,Hibernate可以根据实体类自动创建对应的`User`和`Role`表,以及它们之间的关联。 总结,Hibernate的动态生成表结构功能极大地方便了开发过程,减少了手动创建和维护数据库表的工作量。通过正确配置...

    chepiao.zip_mvc 订票系统_订票

    “Hibernate自动建表”指的是Hibernate,这是一个流行的Java持久层框架,它简化了数据库操作,通过对象关系映射(ORM)技术将Java对象与数据库表对应起来。使用Hibernate,开发者可以定义实体类来代表数据库表,而...

    hibernate建表例子

    在具体的代码示例中,我们将看到如何创建一个名为`User`的实体类,然后使用Hibernate自动在数据库中创建对应的`USER`表。实体类可能会包含`@Id`注解标识主键,以及其他属性和它们对应的列注解。通过SessionFactory...

    spring数据源配置

    - **hibernate.hbm2ddl.auto**: 控制Hibernate自动建表行为。 - **hibernate.show_sql**: 是否显示SQL语句。 - **`mappingResources`**: Hibernate映射文件列表。 ##### 3. 事务管理器配置 为了更好地控制事务...

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

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

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

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

    hibernate简单的入门案例

    3. **自动建表策略** Hibernate 提供了自动创建、更新、验证数据库表的策略。在配置文件中,你可以通过以下属性来控制这个行为: ```xml &lt;property name="hibernate.hbm2ddl.auto"&gt;create ``` 上述配置中的`...

Global site tag (gtag.js) - Google Analytics