hibernate学习之检索策略

  • 检索策略的概念

1.hibernate检索测策略分为两种
(1)立即查询:根据id查询,调用get方法,一调用就发送sql语句查询数据库数据
		Session session = SessionFactoryUtil.GetSession();
		Customer c = session.get(Customer.class, "4028802d5cc56d3b015cc56d3dc50000");
		System.out.println(c);


(2)延迟查询:根据ID查询,还有load方法,调用load方法不会马上发送sql语句查询数据库,只有得到对象里面的值的时候才会发送语句查询数据库
返回有id值,除了id值才会发送sql语句
		Session session = SessionFactoryUtil.GetSession();
		Customer c = session.load(Customer.class, "4028802d5cc56d3b015cc56d3dc50000");
		System.out.println(c.getC_id());
		System.out.println(c.getC_name());

2.延迟查询分为两类:
(1)类级别延迟:根据id查询返回实体类对象,调用load方法,就不会马上发送sql语句,只有需要某个值的时候才会发送sql语句
(2)关联级别延迟:查询出某个客户,再查询这个客户的所有联系人,查询联系人是否需要延迟,这个过程就是关联级别延迟
		Session session = SessionFactoryUtil.GetSession();
		Customer c = session.load(Customer.class, "4028802d5cc56d3b015cc56d3dc50000");
		//在get这个集合时没有发送sql语句
		Set<LinkedMan> lm = c.getLinkedMans();
		//获取这个集合里面值才会发送sql语句
		System.out.println(lm.size());

  • 关联级别延迟操作


<set name="linkedMans" cascade="save-update,delete" lazy="false">
			<!-- 一对多建表
				 hibernate机制:默认双向维护外键,在一和多那一方都需要配置外键
				 column属性值就是外键的名称
			 -->
			<key column="clid"></key>
			<!-- 客户所有的联系人,class里面写的联系人类的全路径 -->
			<one-to-many class="com.sq.entity.LinkedMan"/>
		</set>

  • 批量查询


减少发送的sql语句


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值