Hibernate初体验

来源:互联网 发布:阿特兹原厂轮毂数据 编辑:程序博客网 时间:2024/05/18 15:53

一、何为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;}@Overridepublic String execute() throws Exception {UserDao dao=new UserDaoImp();dao.addUser(this.unumber, this.upassword);return "success";}





原创粉丝点击