大家知道,在Hibernate Framework中,提供了三种查询数据的方式:
1.Hibernate Query Language (HQL):
它是ANSI SQL的最小OO Dialect,例:
session.createQuery("fromCategorycwherec.namelike'Laptop%'"); entityManager.createQuery("selectcfromCategorycwherec.namelike'Laptop%'"); |
2.Criteria query :
它是HQL查询的延伸,提供了一些高级查询功能例:
session.createCriteria(Category.class) .add(Restrictions.like("name","Laptop%")); |
3.NativeSQLquery:
session.createSQLQuery( "select{c.*}fromCATEGORY{c}whereNAMElike'Laptop%'" ).addEntity("c",Category.class); |
最近,我在项目中经常遇到Hibernate数据查询的任务,我对一些我遇到的较难的课题举例进行说明:
《表述SELECT》
Criteriacrit=session.createCriteria(User.class) .setProjection(Projections.projectionList() .add(Projections.property("lastname")) .add(Projections.property("firstname")) .list(); |
《表述WHERE》
Criteriacrit=session.createCriteria(User.class) .add(Restrictions.eq("email","foo@hibernate.org")) .uniqueResult(); |
《表述GROUP》
Criteriacrit=session.createCriteria(User.class) .setProjection(Projections.projectionList() .add(Projections.groupProperty("lastname")) .add(Projections.groupProperty("firstname")) .list() |
《表述ORDER》
Criteriacrit=session.createCriteria(User.class) .addOrder(Order.asc("lastname")) .addOrder(Order.asc("firstname")) .list(); |
《取TOP 5结果》:
Criteriacrit=session.createCriteria(Cat.class); .setMaxResults(5) .list(); |
《分页》:
Criteriacrit=session.createCriteria(Cat.class) .setFirstResult(1) .setMaxResults(50) .list(); |
《取查询结果》:
如果使用select或group,必须使用object[]来获得查询结果List值; 如果未使用select或group,必须使用javaobject[]来获得查询结果List值; |
《涉及组合primary key属性》:
Criteriacrit=session.createCriteria(activitylog.class) .add(Restricts.eq(“comp_id.custId”,customerid0)) .add(Restricts.ge(“createdTs”,starttime)) .add(Restricts.le(“createdTs”,endtime)) .list(); |
《Foreign Key联合查询》:
Criteriacrit=session.createCriteria(activitylog.class) .createAlias(“taskCodeRf”,“tc”) .setProjection(Projections.projectionList() .add(Projections.property("UserId")) .add(Projections.property("tc.taskdescription")) .list(); |
《Native Query》:
SQLQueryquery=session.createSQLQuery(“selectactivitylog_seq.nextvalassessidfromdual”); Query.addScalar(“sessid”,Hibernate.LONG); Longlong0=query.uniqueResult(); |