在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;
}
}