Hibernate技术(3)

原创 2004年01月20日 21:18:00

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

1、  撰写数据库的定义

hibernate需要底层数据库的支持。我们为了测试也要求先建立数据库的相关表格,然后插入一些常用的数据来测试。

数据库的定义如下:

drop table TOY;

drop table CHILD;

drop table employers;

drop table employment_periods;

drop table employees;

 

create table CHILD (

ID NUMBER not null primary key

);

create table TOY (

TOY_ID   NUMBER not null primary key,

CHILD_ID NUMBER ,

POSN     NUMBER default 0,

NAME     varchar(20) default '',

constraint FK_CHILD foreign key (CHILD_ID) references CHILD (ID)

);

DROP SEQUENCE SEQ_TOY;

DROP SEQUENCE SEQ_CHILD;

CREATE SEQUENCE "SEQ_TOY" INCREMENT BY 1 START WITH 1  MAXVALUE 1.0E28 MINVALUE 1 NOCYCLE CACHE 20 NOORDER;

CREATE SEQUENCE "SEQ_CHILD" INCREMENT BY 1 START WITH 1  MAXVALUE 1.0E28 MINVALUE 1 NOCYCLE CACHE 20 NOORDER;

 

主要做了这些工作:申明主键,申明外键,创建主键对应的sequence,注意我们采用的是oracle数据库。

 

2、  好了,我们可以写一个ant脚本来编译我们的程序了

主要的target如下:

定义环境变量:

<path id="myclasspath">

        <fileset dir="${lib}">

                <include name="*.jar"/>

                <include name="*.zip"/>

        </fileset>

        <pathelement location="${build}"/>

    </path>

编译:

<target name="compile" depends="init">

        <echo message="compiling..." />

        <javac srcdir="${src}" destdir="${build}" classpathref="myclasspath"/>

        <copy todir="${build}" />

</target>

 

3、  好了,我们现在可以使用我们的hibernate了。

例如我们插入一个Child,写了一个函数如下:

public int insertChild(Child c) throws HibernateException {

    Transaction tx = null;

    Session s = null;

    try{

      s = HibernateSessionFactory.openSession();

      tx = s.beginTransaction();

      s.save(c);

      tx.commit();

    }catch(HibernateException he){

      if ( tx!=null ){

        tx.rollback();

      }

      throw he;

    }finally{

      s.close();

    }

    return c.getId();

  }

关键部分用红色标出。实际上我们调用了session类的save方法,session类还有很多其他的方法可以调用,如下:update,load,delete等等。传入一个类的引用,便可以保存了。作用类似于insert into …,然后我们的测试代码如下:

//首先实例化三个Toy

Toy t1 = new Toy();

      t1.setName("wawa1");

 

      Toy t2 = new Toy();

      t2.setName("wawa2");

 

      Toy t3 = new Toy();

      t3.setName("wawa3");

 

      Toy[] toys1 = new Toy[] {t1,t2};

      Toy[] toys2 = new Toy[] {t1,t2,t3};

      Toy[] toys3 = new Toy[] {t1,t2};

      Child c = new Child();

      c.setToys(toys1);

      ed.insert(c);//插入含有两个toyChild

 

      c = (Child)ed.findById(c.getClass(),1);//从数据库中取得这个Child

      this.assertEquals(2,c.getToys().length);//应该是两个toy

      c.setToys(toys2);//重新设置toys属性

      ed.update(c);//更新到数据库中

 

 

使用单元测试结果如下:

compile:

     [echo] compiling...

 

test:

     [echo] run test...

     [java] .15:13:21,818  INFO Environment:378 - Hibernate 2.0 beta 6

     [java] 15:13:21,878  INFO Environment:412 - loaded properties from resource hibernate.properties: {hibernate.connection.driver_class=oracle.jdbc.driver.OracleDriver, hibernate.cglib.use_reflection_optimizer=true, hibernate.dialect=net.sf.hibernate.dialect.OracleDialect, hibernate.jdbc.use_streams_for_binary=true, hibernate.jdbc.batch_size=0, hibernate.query.substitutions=true 1, false 0, yes 'Y', no 'N', hibernate.query.imports=net.sf.hibernate.test, net.sf.hibernate.eg, hibernate.connection.username=zhaocw, hibernate.connection.url=jdbc:oracle:thin:@CCSERVER:1521:oracle8i, hibernate.show_sql=true, hibernate.connection.password=zhaocw, hibernate.statement_cache.size=25, hibernate.connection.pool_size=10}

     [java] 15:13:21,898  INFO Environment:426 - using java.io streams to persist binary types

     [java] 15:13:21,898  INFO Environment:427 - using CGLIB reflection optimizer

     [java] 15:13:21,928  INFO Environment:437 - JVM proxy support: true

     [java] 15:13:21,938  INFO Configuration:689 - Configuration resource: /hibernate.cfg.xml

     [java] 15:13:22,929  INFO Configuration:270 - Mapping resource: hibernate/Child.hbm.xml

     [java] 15:13:23,170  INFO Collection:174 - Mapping class: hibernate.Child -> CHILD

     [java] 15:13:23,340  INFO Configuration:270 - Mapping resource: hibernate/Toy.hbm.xml

     [java] 15:13:23,420  INFO Collection:174 - Mapping class: hibernate.Toy -> TOY

     [java] 15:13:24,411  INFO Configuration:871 - Configured SessionFactory: null

     [java] 15:13:24,411  INFO Collection:976 - Mapping collection: hibernate.Child.toys -> TOY

     [java] 15:13:25,242  INFO SessionFactoryImpl:140 - building session factory

     [java] 15:13:25,262  INFO Dialect:37 - Using dialect: net.sf.hibernate.dialect.OracleDialect

     [java] 15:13:25,272  INFO DriverManagerConnectionProvider:41 - Hibernate connection pool size: 10

     [java] 15:13:25,292  INFO DriverManagerConnectionProvider:70 - using driver: oracle.jdbc.driver.OracleDriver at URL: jdbc:oracle:thin:@CCSERVER:1521:oracle8i

     [java] 15:13:25,292  INFO DriverManagerConnectionProvider:71 - connection properties: {user=zhaocw, password=zhaocw}

     [java] 15:13:25,323  INFO PreparedStatementCache:60 - prepared statement cache size: 25

     [java] 15:13:25,333  INFO SessionFactoryImpl:170 - Use outer join fetching: true

     [java] 15:13:26,033  INFO SessionFactoryImpl:193 - Use scrollable result sets: true

     [java] 15:13:26,033  INFO SessionFactoryImpl:202 - echoing all SQL to stdout

     [java] 15:13:27,145  INFO SessionFactoryObjectFactory:82 - no JDNI name configured

     [java] 15:13:27,145  INFO SessionFactoryImpl:287 - Query language substitutions: {no='N', true=1, yes='Y', false=0}

     [java] Hibernate: select SEQ_CHILD.nextval from dual

     [java] Hibernate: select SEQ_TOY.nextval from dual

     [java] Hibernate: select SEQ_TOY.nextval from dual

     [java] Hibernate: insert into CHILD (id) values (?)

     [java] Hibernate: insert into TOY (name, TOY_ID) values (?, ?)

     [java] Hibernate: update TOY set CHILD_ID=?, POSN=? where TOY_ID=?

     [java] Hibernate: select child0_.id as id from CHILD child0_ where child0_.id=?

     [java] Hibernate: select toy0_.TOY_ID as TOY_ID__, toy0_.POSN as POSN__, toy0_.TOY_ID as TOY_ID, toy0_.name as name from TOY toy0_ where toy0_.CHILD_ID=?

     [java] Hibernate: select SEQ_TOY.nextval from dual

     [java] Hibernate: insert into TOY (name, TOY_ID) values (?, ?)

     [java] Hibernate: update TOY set name=? where TOY_ID=?

     [java] Hibernate: update TOY set CHILD_ID=null, POSN=null where CHILD_ID=?

     [java] Hibernate: update TOY set CHILD_ID=?, POSN=? where TOY_ID=?

     [java] Hibernate: select child0_.id as id from CHILD child0_ where child0_.id=?

     [java] Hibernate: select toy0_.TOY_ID as TOY_ID__, toy0_.POSN as POSN__, toy0_.TOY_ID as TOY_ID, toy0_.name as name from TOY toy0_ where toy0_.CHILD_ID=?

     [java] Hibernate: delete from TOY where TOY_ID=?

     [java] Hibernate: update TOY set name=? where TOY_ID=?

     [java] Hibernate: update TOY set CHILD_ID=null, POSN=null where CHILD_ID=?

     [java] Hibernate: update TOY set CHILD_ID=?, POSN=? where TOY_ID=?

 

     [java] Time: 6.269

 

[java] OK (1 test)

 

可以看见实际上hibernate执行的sql语句,测试结果是成功的。

 

五、总结

       实际上,Hibernate可以实现多层次继承的架构,经常用到的包括<many-to-one>,<one-to-many>,<one-to-one>,<subclass>,<joined-subclass>等等。还有组件功能<component>可以让某个属性类存储在父类中。总之,Hibernate功能十分强大,效率也非常搞。建议大家在使用的过程中不断的总结经验,最好能够分享自己的经验。

 

 

相关连接:

hibernate论坛:http://sourceforge.net/forum/forum.php?forum_id=128638

hibernate主页:http://hibernate.sourceforge.net

FAQ: http://hibernate.bluemars.net/14.html?cowiki=c39f9c2408fc3b0ae5d9eeadd0953905#9

 

Hibernate底层技术简介 CGLIB

    从可以看到,基于ASM的开发很复杂,需要了解JVM的底层编码。CGLIB以ASM为基础, 对ASM的功能进行了扩展和封装,提供了更友好的API,部分通用的模版和高级的功能实现。CGLIB的具体...
  • nomad2
  • nomad2
  • 2007年01月21日 12:16
  • 3851

Hibernate框架(一)——总体介绍

作为SSH三大框架之一的Hibernate,是用来把程序的Dao层和数据库打交道用的,它封装了JDBC的步骤,是我们对数据库的操作更加简单,更加快捷。利用Hibernate框架我们就可以不再编写重复的...
  • liujiahan629629
  • liujiahan629629
  • 2014年03月18日 09:40
  • 20464

Hibernate创始人谈ORM、Java的发展

作为Hibernate的创始人,Gavin King身上充满着传奇,坊间流传着很多关于他过往的“英雄”事迹,比如他在设计Hibernate时对SQL知识竟然一点儿也不懂,比如他对Spring创始人Ro...
  • qq_20545159
  • qq_20545159
  • 2015年02月27日 20:09
  • 637

Hibernate ORM实现原理简述

1. 什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射。它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库...
  • wtopps
  • wtopps
  • 2016年08月22日 09:49
  • 1621

精通Hibernate:Java对象持久化技术详解--学习心得--入门(1)

 在Java应用中使用Hibernate包含以下步骤:1.       创建Hibernate的配置文件。2.       创建持久化类。3.       创建对象-关系映射文件。4.       通...
  • Tom_Lee
  • Tom_Lee
  • 2006年12月26日 22:00
  • 1086

Hibernate3.x教程(六) Hibernate常用注解

在Hibernate3.2版本之后,开始支持使用JPA注解来替代XML映射配置,自此,极大程度的简化了hibernate的配置,现在使用注解也成为了映射的首选方式。 下面,我们来学习Hibernat...
  • boyazuo
  • boyazuo
  • 2013年03月16日 14:09
  • 1946

5hibernate3配置参数

SQL方言 1、Hibernate JDBC属性 属性名 用途 hibernate.connection.driver_class jdbc驱动类 hibernate.connection.u...
  • bin71722
  • bin71722
  • 2016年07月12日 16:05
  • 433

Hibernate阶段性总结(一)

hibernate它是一个实现对JDBC轻量级封装的ORM(对象关系映射)的框架。处于项目的持久层。主要学习它的hibernate api和hibernate.cfg.xml,对象关系映射文件 ...
  • baidu_21578557
  • baidu_21578557
  • 2016年06月12日 10:40
  • 2680

spring+hibernate实现分库分表操作

分库的实现: 写一个动态的数据源类 public class DynamicDataSource extends AbstractRoutingDataSource { @Ove...
  • zhongbaolin
  • zhongbaolin
  • 2015年04月16日 17:09
  • 5269

hibernate数据持久化原理

hibernate的持久化机制是采用session容器的方式来缓存数据,当进行save或者update对象时,Hibernate并未将这个对象实际的写入数据库中,而仅仅是在session缓存中根据应用...
  • wangh_2
  • wangh_2
  • 2014年05月19日 17:50
  • 1199
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hibernate技术(3)
举报原因:
原因补充:

(最多只允许输入30个字)