一.hibernate环境的搭建
1.引入jar包
核心包:
hibernate3.jar
required:
antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
javassist-3.12.0.GA.jar
required/jta-1.1.jar
slf4j-api-1.6.1.jar
jpa:
hibernate-jpa-2.0-api-1.0.0.Final.jar
数据库驱动:
mysql-connector-java-5.1.39-bin.jar
2.写对象以及对象的映射
Employee.java对象:
<code>
public class Employee {
private int empId;
private String empName;
private Date workDate;
public int getEmpId() {
return empId;
}
public void setEmpId(int empId) {
this.empId = empId;
}
public String getEmpName() {
return empName;
}
public void setEmpName(String empName) {
this.empName = empName;
}
public Date getWorkDate() {
return workDate;
}
public void setWorkDate(Date workDate) {
this.workDate = workDate;
}
}</code>
Employee.hbm.xml 对象的映射
<code><hibernate-mapping package="com.ycTime.a_hello">
<class name="Employee" table="employee">
<id name="empId" column="id">
<generator class="native"/>
</id>
<property name="empName" column="name"></property>
<property name="workDate" column="workDate"></property>
</class>
</hibernate-mapping></code>
src/hibernate.cfg.xml(数据库连接配置)
<code>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///java_test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<mapping resource="com/ycTime/a_hello/Employee.hbm.xml"/>
</code>
二.hibernateAPI
// 获取加载配置文件的管理类对象
Configuration config = new Configuration();
// 默认加载src/hibernate.cfg.xml文件
config.configure();
// 创建session的工厂对象
SessionFactory sf = config.buildSessionFactory();
// 创建session(代表一个会话,与数据库连接的会话)
Session session = sf.openSession();
Session session = sf.getCurrentSession();
两个都可以获得session,上面的是创建session,下面的是创建或获取session
session对象维护了一次连接,代表了与数据库的会话
// 开启事务
Transaction tx = session.beginTransaction();
hibernate要求所有与数据库的操作,都必须在事务的环境
// 保存到数据库
session.save(emp);
// 提交事务
tx.commit();
// 关闭会话
session.close();
- 对数据库的操作:
session.save(emp);// 保存到数据库
session.update(emp);// 更新数据
session.saveOrUpdate(emp);// 保存或更新数据,没有设置主健,执行保存;设置主健,执行更新;主健不存在,报错。
session.delete(emp);// 删除字段
- 数据查询:
- 主健查询:
<code>
Employee emp = (Employee) session.get(Employee.class,5); // 主健查询
Employee emp = (Employee) session.load(Employee.class, 2); // 主健查询,支持懒加载</code>
- 主健查询:
- HQL查询:
<code>
Query query = session.createQuery("from Employee as e where e.empName = :name");// 区分大小写
query.setString("name", "Sean");
List<Employee> list = query.list();</code>
- Criteria查询:
也叫完全面向对象的查询
<code>
Criteria criteria = session.createCriteria(Employee.class);
criteria.add(Restrictions.eq("empName", "Sean"));
List<Employee> list = criteria.list();</code>
- 本地SQL查询:
对于复杂的查询,或者上面的方式满足不了,就使用本地Sql查询
<code>SQLQuery query = session.createSQLQuery("select * from employee").addEntity(Employee.class);
List<Employee> list = query.list();</code>
三.hibernate配置
主配置文件的配置
自动建表
hibernate.hbm2ddl.auto create-drop
每次在创建sessionfatory时创建表,每次关闭sessionfatory时删除表
hibernate.hbm2ddl.auto create
每次创建表之前先把表删除
hibernate.hbm2ddl.auto update
(最常使用)有表就执行更新,没表就先创建表再执行更新
hibernate.hbm2ddl.auto validate
(生产环境使用)验证,当映射文件和数据库配置不一致时报错
映射配置
<code>
<!--
class 映射一个对象的类
name 指定要映射的对象的类名
table 指定对象对应的表(不写也行,默认与对象name一致)
-->
<class name="Employee" table="worker" >
<!-- 主键 ,映射-->
<id name="empId" column="id" >
<!--
主健的生成策略
identity 自增长(适用于MySQL,db2)
native 自增长(根据底层数据库自增长的方式来选择identity或者sequence)
sequence 自增长(序列),oracle中的自增长策略
increment 会有并发访问问题,一般在集群环境下使用
assigned 指定策略为手动指定主健的值
uuid 指定uuid随即生成的唯一的值
foreign 外键的方式
-->
<generator class="native"/>
</id>
<!--
非主键,映射
property 表的一列
name 指定对象的属性名称
column 对象属性对应的表的字段名称,不写默认与对象name一样
length 字段长度
type 指定表的字段的类型,如果不指定会匹配属性(String, Date)的类型
java类型: 必须写全名
hibernate类型: 直接写就行,都是小写
-->
<property name="empName" column="name" length="15" ></property>
<!-- 如果列名称是数据库关键字,就用`或者改名 -->
<property name="workDate" column="workDate"></property>
</class>
</hibernate-mapping></code>