Hibernate 总结

一、基础知识

①Hibernate是对象/关系映射(Object/Relation Mapping)的解决方案。

②Hibernate架构

POJO

hibernate.cfg.xml

*.hbm.xml

Hibernate应用

二、几个重要的类

Configuration(负责管理Hibernate的配置信息)

当创建SessionFactory时,Configuration实例可以指定使用哪一个映射文挡。应用程序通常只是创建一个Configuration实例,并通过它创建一个SessionFactory实例。

SessionFactory(负责创建Session实例)

它是线程安全的,可以被多线程调用以取得Session,而且构造SessionFactory很消耗资源,所以多数情况下一个应用中只初始化一个SessionFactory,为不同的线程提供Session

Session

SessionHibernate运作的中心,对象的生命周期、事务的管理、数据库的存取都与Session息息相关。Session不是线程安全的,多个执行线程共享一个Session,将会发生数据共享而发生混乱问题。为了解决此问题,可以采用ThreadLocal变量,使用它可以有效隔离执行所使用的数据,也就避开了Session的多线程之间的数据共享问题。

如何调用hibernate API

1、创建Configuration对象。(解析配置文件)

Configuration config = new Configuration();

2、通过Configuration创建Session Factory(线程安全的重量级组件)

Config = config.configure();//configure()方法会在CLASSPATH下寻找hibernate.cfg.xml

SessionFactory = config.buildSessionFactory();

3、通过SessionFactory创建Session会话对象。

Session session = sessionFactory.openSession();

4、通过Session取得事务对象。

Transaction transsession.beginTransaction();

5、通过session与数据库进行会话。

session.save(object o);//

session.delete(object o);//

session.update(object o);//

session.get (Class clazz, Serializable id);//根据Id查找对象

session.createQuery(String sql);//自己拼HQL语言查找对象返回一个Query对象。

6、提交操作,结束事务。

Trans.commit();

7、关闭Session

session.close();

注:第一步和第二步一般放在静态初始化代码块中执行。

三、Hibernate中自带IDgenerator的含义:

1identity:用于MySql数据库。特点:递增

<id name="id" column="id">

<generator class="identity"/>

</id>

注:对于MySql数据库使用递增序列时需要在建表时对主键指定为auto_increment属性。

2sequence:用于Oracle数据库

<id name="id" column="id">

<generator class="sequence">

<param name="sequence">序列名</param>

</generator>

</id>

3native:跨数据库时使用,由底层方言产生。

Default.sequencehibernate_sequence

<id name="id" column="id">

<generator class="native"/>

</id>

注:使用nativeHibernate默认会去查找Oracle中的hibernate_sequence序列。

如果Oracle中没有该序列,连Oracle数据库时会报错。

4hilo:通过高低位合成id,先建表hi_value,再建列next_value。必须要

有初始值。

<id name="id" column="id">

<generator class="hilo">

<param name="table">high_val</param>

<param name="column">nextval</param>

<param name="max_lo">5</param>

</generator>

</id>

5sequencehilo:同过高低位合成id,建一个sequence序列,不用建表。

<id name="id" column="id">

<generator class="hilo">

<param name="sequence">high_val_seq</param>

<param name="max_lo">5</param>

</generator>

</id>

6assigned:用户自定义id;

<id name="id" column="id">

<generator class="assigned"/>

</id>

7foreign:用于一对一关系共享主健时,两id值一样。

四、Hibernate类关系的处理:

1OnetoOne关系在数据库中如何体现,在JavaBean中如何体现,在Hibernate中如何映射onetoone关系。

1、数据库中:一个表的外健对应另一个表的主健,外健要加上Unique约束。或者是两个表共享一个主健。

2javaBean中:在JavaBean中增加一个属性,即另外一个对象的引用,可以单向也可以双向。

3、在hibernate中:

主健映射:都是onetoone要用foreign生成策略。

外健映射:主表中用onetoone,副表通过propertyrefmanytoone

create table car_pk (

id number(10,0) not null,

name varchar2(15),

serial varchar2(30),

manufacturer varchar2(50),

producedate date,

primary key (id)

);

create table engine_pk (

id number(10,0) not null,

model varchar2(20),

manufacturer varchar2(50),

producedate date,

primary key (id)

);

alter table engine_pk

add constraint fk_engine_car_pk

foreign key (id)

references car_pk(id);

One-to-OnePK主键映射 (详见代码)

Tablecar_pk

Id

name

serial

manufacturer

producedate

Tableengine_pk

Id

model

manufacturer

producedate

特点:engine_pk表的Idcar_pk表共享主键。

One-to-OneFK外键映射(详见代码)

Tablecar_pk

Id

name

serial

manufacturer

producedate

Tableengine_fk

Id

carid

model

manufacturer

producedate

特点:engine_fk表多了carid外键字段来维护与car_fk表的关系。

建表语句如下:

create table engine_fk (

id number(10,0) not null,

model varchar2(20) not null,

manufacturer varchar2(50) not null,

producedate date,

carid number(10,0) unique,

primary key (id)

);

alter table engine_fk

add constraint fk_engine_car_fk

foreign key (carid)

references car_fk(id);



转自:http://blog.csdn.net/chenpy/article/details/1736474

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值