Hibernate在MVC的设计模式中,充当的是M(Model)模型层(或数据访问层),其实现的功能是将Java对象或是叫PO对象映射到数据库,然后通过操作PO,实现对数据 的增删改查等功能。
Hibernate的工作流程图如下所示:
1、应用程序调用Configration类,读取配置文件及映射文件信息
Configuration cfg =
new
Configuration().configure();
2、使用读取的配置信息生成SessionFactory对象
factory = cfg.buildSessionFactory();
3、从SessionFactory生成Session对象
Session session=factory.openSession()
4、通过Session生成Transaction对象
tran=session.beginTransaction
5、session对象的get(),load(),delete(),update(),saveOrUpdate()等方法对PO对象进行操作;若是查询情况Session对象将会生成一个Query对象,利用该对象进行查询操作;若发生异常进行回滚操作,没有异常,Transaction将操作结果提交到数据库中。
HQL查询
Query query = session.createQuery("from News ");
List<News> list = query.list();
HQL是Hibernate主推的查询方式,和普通SQL语句也比较接近,但很重要一点不同就是HQL中from后面的是JAVA类名,不是库表名,切忌!!!其它就是如果查询全字段 "select *" 可以省略不写。
.SqlQuery查询
List<News> list = session.createSQLQuery("select * from News").addEntity(News.class).list();
addEntity 不能忘记,这种查询方式是把查询好的结果放到一个实体中,再遍历操作,不推荐使用。
6、关闭Session
session.close();
从Hibernate的原理流程图中我们知道,Hibernate的核心组件包括:
1、Configuration类:用来读取Hibernate配置文件,并生成SessionFactory对象。
2、SessionFactory接口:产生Session实例工厂。
3、Session接口:用来操作PO。它有get(),load(),save(),update()和delete()等方法用来对PO进行加载,保存,更新及删除等操作。它是Hibernate的核心接口。
4、Query接口:用来对PO进行查询操。它可以从Session的createQuery()方法生成。
5、Transaction接口:用来管理Hibernate事务,它主要方法有commit()和rollback(),可以从Session的beginTrancation()方法生成。
2、SessionFactory接口:产生Session实例工厂。
3、Session接口:用来操作PO。它有get(),load(),save(),update()和delete()等方法用来对PO进行加载,保存,更新及删除等操作。它是Hibernate的核心接口。
4、Query接口:用来对PO进行查询操。它可以从Session的createQuery()方法生成。
5、Transaction接口:用来管理Hibernate事务,它主要方法有commit()和rollback(),可以从Session的beginTrancation()方法生成。
下面来编写一个Hibernate实例;
1、创建一个Java项目,其结构目录如下
上图中的Referenced libraries引入MYsql_JDBC连接驱动Jar包;
2、建立User实体类,其代码如下:
package com.suo;
/**
* User entity. @author MyEclipse Persistence Tools
*/
public class User implements java.io.Serializable {
// Fields
private Integer id;
private String name;
private String password;
private String email;
private String address;
// Property accessors
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return this.password;
}
public void setPassword(String password) {
this.password = password;
}
public String getEmail() {
return this.email;
}
public void setEmail(String email) {
this.email = email;
}
public String getAddress() {
return this.address;
}
public void setAddress(String address) {
this.address = address;
}
}
3、User的Hibernate映射文件User.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="com.suo.User" table="user" catalog="baseframe">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="name" type="java.lang.String">
<column name="name" length="25" />
</property>
<property name="password" type="java.lang.String">
<column name="password" length="25" />
</property>
<property name="email" type="java.lang.String">
<column name="email" length="25" />
</property>
<property name="address" type="java.lang.String">
<column name="address" length="25" />
</property>
</class>
</hibernate-mapping>
4、Hibernate的配置文件的配置(主要用于连接数据库)
hibernate.cfg.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<!-- mysql数据库驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- mysql数据库名称 -->
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/baseframe</property>
<!-- 数据库的登陆用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库的登陆密码 -->
<property name="hibernate.connection.password">root</property>
<!-- 方言:为每一种数据库提供适配器,方便转换 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<mapping resource="com/suo/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
5、客户端程序的编写
Client.java
package com.suo;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;
public class Client {
public static void main(String[] args) {
//读取配置文件
Configuration cfg=new Configuration().configure();
//生成session工厂类
SessionFactory factory=cfg.buildSessionFactory();
Session session=null;
try {
//打开session
session = factory.openSession();
//开启事物
session.beginTransaction();
User user = new User();
user.setName("2016");
user.setPassword("12");
user.setEmail("04");
user.setAddress("21:33");
//session操作
session.save(user);
//提交数据库
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
//异常处理
session.getTransaction().rollback();
}finally{
if(session!=null){
//关闭session
session.close();
}
}
}
}
源码下载地址:
点击打开链接