Hibernate初体验

一、何为Hibernate?

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。

二、Hibernate的核心

Hibernate的核心组件
在基于MVC设计模式的JAVA WEB应用中,Hibernate可以作为模型层/数据访问层。它通过配置文件(hibernate.properties或hibernate.cfg.xml)和映射文件(***.hbm.xml)把JAVA对象或PO(Persistent Object,持久化对象)映射到数据库中的数据库,然后通过操作PO,对数据表中的数据进行增,删,改,查等操作。
除配置文件,映射文件和持久化类外,Hibernate的核心组件包括以下几部分:
a)Configuration类:用来读取Hibernate配置文件,并生成SessionFactory对象。
b)SessionFactory接口:产生Session实例工厂。
c)Session接口:用来操作PO。它有get(),load(),save(),update()和delete()等方法用来对PO进行加载,保存,更新及删除等操作。它是Hibernate的核心接口。
d)Query接口:用来对PO进行查询操。它可以从Session的createQuery()方法生成。
e)Transaction接口:用来管理Hibernate事务,它主要方法有commit()和rollback(),可以从Session的beginTrancation()方法生成。

三、Hibernate是如何运行的?

Hibernate的运行过程如下:
A:应用程序先调用Configration类,该类读取Hibernate的配置文件及映射文件中的信息,并用这些信息生成一个SessionFactpry对象。
B:然后从SessionFactory对象生成一个Session对象,并用Session对象生成Transaction对象;可通过Session对象的get(),load(),save(),update(),delete()和saveOrUpdate()等方法对PO进行加载,保存,更新,删除等操作;在查询的情况下,可通过Session对象生成一个Query对象,然后利用Query对象执行查询操作;如果没有异常,Transaction对象将 提交这些操作结果到数据库中。

附:
Persistent Object
持久化对象可以是普通的Javabeans,惟一特殊的是它们与(仅一个)Session相关联。JavaBeans在Hibernate中存在三种状态:
1.临时状态(transient):当一个JavaBean对象在内存中孤立存在,不与数据库中的数据有任何关联关系时,那么这个JavaBeans对象就称为临时对象(Transient Object)。
2.持久化状态(persistent):当一个JavaBean对象与一个Session相关联时,就变成持久化对象(Persistent Object)
3.脱管状态(detached):在这个Session被关闭的同时,这个对象也会脱离持久化状态,就变成脱管状态(Detached Object),可以被应用程序的任何层自由使用,例如可以做与表示层打交道的数据舆对象(Data Transfer Object)。

下面是简单的实例:

数据:
create table Myuser
(
    uid    
int primary key,
    unumber 
varchar(30),
    upassword 
varchar(30)
)


视图层:index.jsp(使用了EasyUI)

<body>
<table id="dg"></table>
 <script type="text/javascript">
 	$(function(){
		 var DoubleIndex;//双击
		var SingleIndex;//单击
		$('#dg').datagrid({    
			rownumbers:true,
			fitColumns:true,
			checkOnSelect:true,
			url:"user.action",
	        type:'post', 
			columns:[[
				{field:"ck",checkbox:"true" },
				{field:"uid", title:"用户编号"},
				{field:"unumber", title:"用户账号","editor":{type:'validatebox'}},
				{field:"upassword", title:"用户密码","editor":{type:'validatebox'}}
			]]
)}
</body>

对象Myuser.java

public class Myuser {
	private int uid;
	private String unumber;
	private String upassword;
	public int getUid() {
		return uid;
	}
	public void setUid(int uid) {
		this.uid = uid;
	}
	public String getUnumber() {
		return unumber;
	}
	public void setUnumber(String unumber) {
		this.unumber = unumber;
	}
	public String getUpassword() {
		return upassword;
	}
	public void setUpassword(String upassword) {
		this.upassword = upassword;
	}
	
	public Myuser(int uid, String unumber, String upassword) {
		super();
		this.uid = uid;
		this.unumber = unumber;
		this.upassword = upassword;
	}
	public Myuser() {
		super();
	}
	public Myuser(String unumber, String upassword) {
		super();
		this.unumber = unumber;
		this.upassword = upassword;
	}
	public Myuser(int uid) {
		super();
		this.uid = uid;
	}
		

}

设计映射文件Myuser.hbm.xml

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
    <class name="entity.Myuser" table="MYUSER">
        <id name="uid" type="int">
            <column name="UID" />
            <generator class="assigned" />
        </id>
        <property name="unumber" type="java.lang.String">
            <column name="UNUMBER" />
        </property>
        <property name="upassword" type="java.lang.String">
            <column name="UPASSWORD" />
        </property>
    </class>
</hibernate-mapping>

设计Hibernate配置文件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>
		<!-- 配置数据库的连接信息 -->  
		<property name="connection.username">数据库用户名</property> 
		<property name="connection.password">数据库密码</property> 
		<property name="connection.url">jdbc:mysql://localhost:3306/mydb</property> 
		<property name="connection.driver_class">com.mysql.jdbc.Driver</property>      
		
		
		<!-- 显示SQL语句 -->
		<property name="show_sql">true</property>
		
		
		<!-- 关联映射文件 -->
		<mapping resource="entity/Myuser.hbm.xml"/>
		
    </session-factory>
</hibernate-configuration>

SessionHelper类(可以不写,在dao层或者action里直接手写)

public class SessionHelper {
	private static  SessionFactory sessionFactory; 
	private static  Session session; 
	private static  Transaction transaction;
	
	public static Session getSession(){
		Configuration configuration=new Configuration().configure("hibernate.cfg.xml");
		sessionFactory = configuration.buildSessionFactory();
		session = sessionFactory.openSession();
		transaction = session.beginTransaction();
		
		return session;
	}
	
	public static void CloseAll(){
		transaction.commit();
		session.close();
		sessionFactory.close();
	}
}


dao层(方法)

public List<Myuser> getAll(){
Session session=SessionHelper.getSession();
List<Myuser> users=session.createCriteria(Myuser.class).list();
SessionHelper.CloseAll();
return users;
}



user.action

	private String unumber;
	private String upassword;
	
	public String getUnumber() {
		return unumber;
	}

	public void setUnumber(String unumber) {
		this.unumber = unumber;
	}

	public String getUpassword() {
		return upassword;
	}

	public void setUpassword(String upassword) {
		this.upassword = upassword;
	}

	@Override
	public String execute() throws Exception {
		UserDao dao=new UserDaoImp();
		dao.addUser(this.unumber, this.upassword);
		
		return "success";
	}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值