hibernate.hbm2ddl.auto
时间: 2023-04-27 08:02:23 浏览: 179
hibernate.hbm2ddl.auto是Hibernate配置文件中的一个属性,用于指定Hibernate在启动时如何自动创建和更新数据库表结构。它有以下几个可选值:
1. validate:Hibernate启动时会校验实体类和数据库表结构是否一致,如果不一致则会抛出异常。
2. update:Hibernate启动时会根据实体类的定义自动更新数据库表结构,但不会删除已经存在的表或字段。
3. create:Hibernate启动时会根据实体类的定义自动创建数据库表结构,但如果表已经存在则会抛出异常。
4. create-drop:Hibernate启动时会根据实体类的定义自动创建数据库表结构,但在Hibernate关闭时会自动删除表结构。
一般来说,我们在开发阶段使用update或create,而在生产环境中使用validate或不设置该属性。
相关问题
hbm2ddl.auto
hbm2ddl.auto是Hibernate框架中的一个配置属性,用于自动创建数据库表结构的功能。它有以下几个可选值:
- `create`: 每次启动应用程序时,都会删除现有的数据库表并重新创建新的表结构。
- `create-drop`: 每次启动应用程序时,都会删除现有的数据库表并重新创建新的表结构。当应用程序关闭时,也会删除这些表。
- `update`: 每次启动应用程序时,会根据实体类的定义和数据库表结构的差异来更新数据库表结构。
- `validate`: 每次启动应用程序时,会校验实体类的定义和数据库表结构是否一致,如果不一致则会抛出异常。
这个属性通常是在Hibernate的配置文件中进行设置,以告诉Hibernate如何处理数据库表结构与实体类之间的映射关系。需要注意的是,在生产环境中,通常不建议使用`create`或`create-drop`选项,因为这会导致现有数据的丢失。而`update`或`validate`选项则更适合生产环境的使用。
编写Hibernate5的配置文件hibernate.cfg.xml,编写加载配置文件的类HibernateSessionFactory,编写持久化类Teachinfo和映射文件Teachinfo.hbm.xml,编写一个类名为TeacherDao的JavaBean,该类封装了对教师信息的增删改查操作。
以下是Hibernate5的配置文件hibernate.cfg.xml:
```xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/testdb</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
</session-factory>
</hibernate-configuration>
```
接下来是加载配置文件的类HibernateSessionFactory:
```java
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class HibernateSessionFactory {
private static SessionFactory sessionFactory;
private HibernateSessionFactory() {
}
public static SessionFactory getSessionFactory() {
if (sessionFactory == null) {
Configuration configuration = new Configuration();
configuration.configure("hibernate.cfg.xml");
sessionFactory = configuration.buildSessionFactory();
}
return sessionFactory;
}
}
```
然后是持久化类Teachinfo和映射文件Teachinfo.hbm.xml:
Teachinfo.java
```java
public class Teachinfo {
private int id;
private String name;
private int age;
private String sex;
public Teachinfo() {
}
public Teachinfo(int id, String name, int age, String sex) {
this.id = id;
this.name = name;
this.age = age;
this.sex = sex;
}
// 省略getter和setter方法
}
```
Teachinfo.hbm.xml
```xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="Teachinfo" table="teachinfo">
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="name" column="name"/>
<property name="age" column="age"/>
<property name="sex" column="sex"/>
</class>
</hibernate-mapping>
```
最后是TeacherDao类,封装了对教师信息的增删改查操作:
```java
import org.hibernate.Session;
import org.hibernate.Transaction;
public class TeacherDao {
public void add(Teachinfo teachinfo) {
Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession();
Transaction tx = session.beginTransaction();
session.save(teachinfo);
tx.commit();
}
public void delete(int id) {
Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession();
Transaction tx = session.beginTransaction();
Teachinfo teachinfo = (Teachinfo) session.load(Teachinfo.class, id);
session.delete(teachinfo);
tx.commit();
}
public void update(Teachinfo teachinfo) {
Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession();
Transaction tx = session.beginTransaction();
session.update(teachinfo);
tx.commit();
}
public Teachinfo getById(int id) {
Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession();
Transaction tx = session.beginTransaction();
Teachinfo teachinfo = (Teachinfo) session.get(Teachinfo.class, id);
tx.commit();
return teachinfo;
}
}
```
阅读全文