首页 > 代码库 > 攻城狮在路上(壹) Hibernate(二)--- 第一个hibernate程序

攻城狮在路上(壹) Hibernate(二)--- 第一个hibernate程序

1、直接通过JDBC API持久化实体域对象

  A、java.sql常用接口和类:

    DriverManager:驱动程序管理器,负责创建数据库连接。

    Connection:代表数据库连接。

    Statement:负责执行SQL语句。

    PreparedStatement:负责执行SQL语句,具有预定义SQL语句的功能。

    ResultSet:代码SQL查询语句的查询结果集。

 2、常用的ORM中间件

  Hibernate\Mybatis\Toplink\Torque\ObjectRelationBridge\FrontierSuite\Castor\FreeFROM\Expresso\JRelationFramework\VBSF\Jgrinder

3、Hibernate 核心接口

  A、Configuration类:用来读取Hibernate配置文件,并生成SessionFactory对象。在Hibernate 的启动过程中,Configuration 类的实例首先定位映射文档的位置,读取这些配置,然后创建一个SessionFactory对象。 
  B、SessionFactory接口:产生Session实例工厂。SessionFactory在Hibernate中实际起到了一个缓冲区的作用,它缓冲了Hibernate自动生成的SQL语句和一些其它的映射数据,还缓冲了一些将来有可能重复利用的数据。 
  C、Session接口:用来操作PO。它有get(),load(),save(),update()和delete()等方法用来对PO进行加载,保存,更新及删除等操作。它是Hibernate的核心接口。Session 对象是非线程安全的,因此在你的设计中,最好是一个线程只创建一个Session对象。 
  D、Query接口:来对PO进行查询操。它可以从Session的createQuery()方法生成。Query接口让你方便地对数据库及持久对象进行查询,它可以有两种表达方式:HQL语言或本地数据库的SQL语句。Query经常被用来绑定查询参数、限制查询记录数量,并最终执行查询操作。

  E、Criteria接口Criteria接口与Query接口非常类似,它允许你创建并执行面向对象的标准化查询。
  F、Transaction接口:用来管理Hibernate事务,它主要方法有commit()和rollback(),可以从Session的beginTrancation()方法生成。

  G、Callback 接口当一些有用的事件发生时――例如持久对象的载入、存储、删除时,Callback 接口会通知Hibernate去接收一个通知消息。Interceptor,Lifecycle,和Validatable接口。

  H、策略接口当你感觉到Hibernate 的某些功能不足,或者有某些缺陷时,你可以开发一个自己的策略来替换它,而你所要做的仅仅只是继承它的某个策略接口,然后实现你的新策略就可以了

    主键的生成 (IdentifierGenerator 接口)
    本地SQL语言支持 (Dialect 抽象类)
    缓冲机制 (Cache 和CacheProvider 接口)
    JDBC 连接管理 (ConnectionProvider接口)
    事务管理 (TransactionFactory, Transaction, 和 TransactionManagerLookup 接口)
    ORM 策略 (ClassPersister 接口)
    属性访问策略 (PropertyAccessor 接口)
    代理对象的创建 (ProxyFactory接口)

  I、用于扩展Hibernate的功能的接口:UserType,CompositeUserType

 四、使用hibernate的一般步骤

  A、创建hibernate的配置文件。

  B、创建持久化类。

  C、创建对象-关系映射文件。

  D、通过hibernate API编写访问数据库的代码。

五、第一个hibernate程序

    A、hibernate.properties:

?
1
2
3
4
5
6
hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.connection.driver_class=com.mysql.jdbc.Driver
hibernate.connection.url=jdbc:mysql://localhost:3306/SAMPLEDB
hibernate.connection.username=root
hibernate.connection.password=root
hibernate.show_sql=true

  B、创建持久化类:

  C、创建对象-关系映射文件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<?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="mypack.Customer" table="CUSTOMERS">
      
   
    <id name="id" column="ID" type="long">
      <generator class="increment"/>
    </id>
    <property name="name"  column="NAME"  type="string" not-null="true" /> 
    <property name="email"     column="EMAIL"     type="string" not-null="true" />
    <property name="password"  column="PASSWORD"  type="string" not-null="true"/>
    <property name="phone"     column="PHONE"     type="int" />
    <property name="address"   column="ADDRESS"   type="string" />
    <property name="sex"       column="SEX"       type="character"/> 
    <property name="married"   column="IS_MARRIED"  type="boolean"/>     
    <property name="description"   column="DESCRIPTION"  type="text"/>     
    <property name="image"         column="IMAGE"        type="binary"/>
    <property name="birthday"      column="BIRTHDAY"     type="date"/>
    <property name="registeredTime" column="REGISTERED_TIME"  type="timestamp"/> 
 
  </class>
 
</hibernate-mapping>

  D、通过hibernate API编写访问数据库的代码: