Hibernate详解HQL_QBL查询

本文详细介绍了Hibernate的查询方式,包括OID查询、对象导航查询、HQL检索(基本查询、排序、条件、投影及多表查询)、QBC查询(简单、排序、分页和条件查询)以及SQL检索。重点讨论了HQL的特点和用法,如投影查询、分页查询和多表连接。同时,文章还提及了Hibernate的抓取策略,如延迟加载和不同级别的延迟加载配置。
摘要由CSDN通过智能技术生成

Hibernate的查询方式

Hibernate提供了5种查询方式:

1.OID查询

根据对象OID(主键)进行检索,使用get方法;使用load方法。

2.对象导航查询

根据一个已查询到的对象,获得关联对象。

LinkMan linkMan = session.get(LinkMan.class, 1l);
Customer customer = linkMan.getCustomer();//根据查询对象获得关联对象

3.HQL检索

HIbernate Query Language ,Hibernate的查询语言,是一种面向对象的查询方式语言,语法类似SQL。通过session.createQuery(),用于接收一个HQL进行查询的方式。

HQL查询所有使用:from 表名;  而不使用select * from 表名;  应为HQL不能直接查询* 但是可以查询COUNT(*)查询到的是Long类型的值。

我们首先创建一张一对多的表:

基本查询

	@Test//HQL的简单查询
	public void test2(){
		Session session = HibernateUtils.getCurrentSession();
		Transaction transaction = session.beginTransaction();
		
		Query query = session.createQuery("from Customer");
		//也可取别名查询,别名查询可以select c.cust_name from Customer c
//		Query query2 = session.createQuery("select c from Customer c");//第二个c是别名
		List<Customer> list = query.list();
		for (Customer customer : list) {
			System.out.println(customer);
		}
		transaction.commit();
	}

排序查询

	@Test//排序查询
	public void test3(){
		Session session = HibernateUtils.getCurrentSession();
		Transaction transaction = session.beginTransaction();
		
//		Query query = session.createQuery("from Customer order by cust_id asc");//asc是升序,默认值可不写
		Query query2 = session.createQuery("from Customer order by cust_id desc");//desc是降序
		List<Customer> list = query2.list();
		for (Customer customer : list) {
			System.out.println(customer);
		}
		transaction.commit();
	}

条件查询

一、按位置绑定:根据参数位置进行绑定

		//查询姓名以杨开头,来源是网络的对象customer
		Query query = session.createQuery("from Customer where cust_name like ? and cust_source=?");
		query.setParameter(0, "杨%");
		query.setParameter(1, "网络");
		List<Cust
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值