hibernate读书篇2

hibernate读书篇2
单向一对多关联:

主控方:(即父亲一方)

<set

name="addresses"

table="t_address"

lazy="false"

inverse="false"

cascade="all"

sort="unsorted"

order-by="zipcode asc">

<key column="user_id"><!--< span="" /-->key>

<one-to-many class="org.hibernate.sample.TAddress"

/>

<!--< span="" /-->set>

被动方(Taddress)的记录由Hibernate 负责读取,之后存放在主控方指定的Collection类型属性中。

双向一对多关联:

主控端:

<set

name="addresses"

table="t_address"

lazy="false"

inverse="true" ①将这个属性设置为TRUE即可

cascade="all"

sort="unsorted"

order-by="zipcode asc">

<key column="user_id" ><!--< span="" /-->key>

<one-to-many class="org.hibernate.sample.TAddress"

/>

<!--< span="" /-->set>

被控端:

<many-to-one

name="user"

class="org.hibernate.sample.TUser"

cascade="none"

outer-join="auto"

update="true"

insert="true"

access="property"

column="user_id"

not-null="true"

/>

多对多关系:

主控端:

<set

name="roles"

table="t_group_role"

lazy="false"

inverse="false"

cascade="save-update"

>

<key column="group_id" >

<!--< span="" /-->key>

<many-to-many class="org.hibernate.sample.TRole"

column="role_id" />

<!--< span="" /-->set>

被控端:

<set

name="groups"

table="t_group_role"

lazy="false"

inverse="true"

cascade="save-update"

sort="unsorted">

<key column="role_id"><!--< span="" /-->key>

<many-to-many

class="org.hibernate.sample.TGroup"

column="group_id"

outer-join="auto"/>

14TUser user = (TUser)session.load(TUser.class,new Integer(1));

15)悲观锁:用FOR UPDATE

String hqlStr ="from TUser as user where user.name='Erica'";

Query query = session.createQuery(hqlStr);

query.setLockMode("user",LockMode.UPGRADE); //加锁

List userList = query.list();//执行查询,获取数据

16)乐观锁:用版本控制

<class

name="org.hibernate.sample.TUser"

table="t_user"

dynamic-update="true"

dynamic-insert="true"

optimistic-lock="version"

>

……

<!--< span="" /-->class>

事务主要包括JTA事务,JDBC事务

1)Session.load(对象类,ID)直接读取对象

2)Session.get(对象类,ID)直接读取对象,如果对象不能知道是否存在,如果不存在返回NULL

3)Session.iterate(HQL)直接返回一个ITERATOR接口的对象实例

4)Query q = Session.createQuery(HQL), List result =q.list();得到LIST结果集

5)Criteria crit = session.createCriteria(Cat.class);条件查询

crit.add( Expression.eq("color", eg.Color.BLACK) );

crit.setMaxResults(10);

List cats = crit.list();

- 作者: lightsword 2006年02月28日, 星期二 09:50  回复(0) |  引用(0) 加入博采

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值