在hibernate中我们使用注解,可以帮助我们简化hbm文件配置。

hibernate.cfg.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>
        <!-- 配置关于数据库连接的四个项 driverClass url username password -->
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql:///hibernateTest</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">abc</property>

        <!-- 设置连接提供者 -->
        <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
        <!-- c3p0连接池的配置 -->
        <property name="hibernate.c3p0.max_size">20</property> <!-- 最大连接池 -->
        <property name="hibernate.c3p0.min_size">5</property> <!-- 最小连接数 -->
        <property name="hibernate.c3p0.timeout">120</property> <!-- 超时 -->
        <property name="hibernate.c3p0.idle_test_period">3000</property> <!-- 空闲连接 -->

        <!-- 可以将向数据库发送的sql显示出来 -->
        <property name="hibernate.show_sql">true</property>
        <!-- 格式化sql -->
        <property name="hibernate.format_sql">true</property>

        <!-- hibernate的方言 -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

        <!-- 自动创建表 -->
        <property name="hibernate.hbm2ddl.auto">update</property>

        <mapping class="cn.nwtxxb.domain.Book" />
        <mapping class="cn.nwtxxb.domain.Person" />

        <mapping class="cn.nwtxxb.oneToMany.Customer" />
        <mapping class="cn.nwtxxb.oneToMany.Order" />

        <mapping class="cn.nwtxxb.manyToMany.Teacher" />
        <mapping class="cn.nwtxxb.manyToMany.Student" />


        <mapping class="cn.nwtxxb.oneToOne.User" />

        <mapping class="cn.nwtxxb.oneToOne.IDCard" />

        <mapping class="cn.nwtxxb.oneToOne.Husband" />
        <mapping class="cn.nwtxxb.oneToOne.Wife" />
    </session-factory>

</hibernate-configuration>  

PO类注解配置

@Entity 声明一个实体
@Table来描述类与表对应
1、 首先配置我们的类名与数据库对应。

@Entity // 定义了一个实体
@Table(name = "t_book", catalog = "hibernateTest")
public class Book {

}

2、 声明实体类的id:@GenerateValue如果不设置变量默认是native(自动选择)

@Id // 主键
// @GeneratedValue //native
@GeneratedValue(strategy = GenerationType.IDENTITY) // identity
private Integer id; // 主键

3、 普通类型配置:nullable是否为空,如果不设置@Column默认匹配属性类型,数据库字段与属性名称相同。

@Column(name = "c_name", length = 30, nullable = true)
private String name;

4、 日期类型配置:@Temporal有三种类型:
1)TemporalType.DATA 只有年月日
2)TemporalType.TIME 只有小时分钟秒
3)TemporalType.TIMESTAMP 有年月日小时分钟秒

@Temporal(TemporalType.TIMESTAMP) // 是用来定义日期类型
private Date publicationDate; // 出版日期

5、 配置完所有属性需要在hibernate核心配置文件中引入实体类。

<mapping class="cn.nwtxxb.domain.Book" />

如何使用uuid主键生成策略。自己声明一个uuid,然后在通过@GeneratedValue标签引入即可。

@Id
@GenericGenerator(name = "myuuid", strategy = "uuid")
@GeneratedValue(generator = "myuuid")
private String id;

普通属性还可以用@Type声明类型。

@Type(type="string")
private String name;

如果类中的属性不想在表中生成列,可以用@Transient

@Transient
private String msg; // 这个属性不想生成在表中

所有的配置都可以放到属性的get方法上配置。

@Entity
@Table(name = "t_person", catalog = "hibernateTest")
public class Person {

    @Id
    @GenericGenerator(name = "myuuid", strategy = "uuid")
    @GeneratedValue(generator = "myuuid")
    private String id;

    @Type(type="string")
    private String name;

    @Transient
    private String msg; // 现在这个属性不想生成在表中

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

}