Hibernate高级查询实战

大家知道,在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","[email protected]"))
.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();

你可能感兴趣的:(Hibernate)