Hibernate高级查询实战

本文详细介绍了在Hibernate框架中实现数据查询的三种主要方式:Hibernate Query Language (HQL)、Criteria查询以及Native SQL查询,并通过具体示例展示了如何进行筛选、分组、排序以及获取特定数量的结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家知道,在Hibernate Framework中,提供了三种查询数据的方式:

 

1. Hibernate Query Language (HQL):


   它是ANSI SQL的最小OO Dialect,例:

session.createQuery("from Category c where c.name like 'Laptop%'");
entityManager.createQuery("select c from Category c where c.name like 'Laptop%'");

 

2. Criteria query :


   它是HQL查询的延伸,提供了一些高级查询功能,例:

session.createCriteria(Category.class).add( Restrictions.like("name", "Laptop%") );

 

3. Native SQL query :

 

session.createSQLQuery("select {c.*} from CATEGORY {c} where NAME like 'Laptop%'").addEntity("c", Category.class);

 

 

《表述SELECT》

Criteria crit = session.createCriteria(User.class)
.setProjection( Projections.projectionList()
.add( Projections.property("lastname"))
.add( Projections.property("firstname"))
.list();

 

《表述WHERE》

Criteria crit = session.createCriteria(User.class)
.add(Restrictions.eq("email", "foo@hibernate.org"))
.uniqueResult();

 

《表述GROUP》

Criteria crit = session.createCriteria(User.class)
.setProjection( Projections.projectionList()
.add( Projections.groupProperty("lastname"))
.add( Projections.groupProperty("firstname"))
.list()


《表述ORDER》

Criteria crit = session.createCriteria(User.class)
.addOrder( Order.asc("lastname") )
.addOrder( Order.asc("firstname") )
.list();

 

 《取TOP 5结果》

Criteria crit = session.createCriteria(Cat.class);
.setMaxResults(5)
.list();


  《分页》

Criteria crit = session.createCriteria(Cat.class)
.setFirstResult(1)
.setMaxResults(50)
.list();

 

   《取查询结果》

    如果使用select或group,必须使用object[]来获得查询结果List值;
    如果未使用select或group,必须使用java object[]来获得查询结果List值;

 

   《涉及组合primary key属性》

Criteria crit = session.createCriteria(activitylog.class)
.add( Restricts.eq(“comp_id.custId”,customerid0) )
.add( Restricts.ge(“createdTs”, starttime) )
.add( Restricts.le(“createdTs”, endtime ) )
.list();

 

   《Foreign Key联合查询》

Criteria crit = session.createCriteria(activitylog.class)
.createAlias( “taskCodeRf”, “tc” )
.setProjection( Projections.projectionList()
.add( Projections.property("UserId"))
.add( Projections.property("tc.taskdescription"))
.list();

  

   《Native Query》

SQLQuery query = session.createSQLQuery(“select  activitylog_seq.nextval as sessid from dual”);
Query.addScalar(“sessid”,Hibernate.LONG);
Long long0 = query.uniqueResult();

 




 

   

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值