Hibernate Framework查詢實(shí)例
本文主要介紹在Hibernate Framework中的三種查詢數(shù)據(jù)的方式,下面就三種方式一一舉例,希望大家閱讀后有很大的收益。
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查詢的延伸,提供了一些Hibernate Framework高級查詢功能,例:
- 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);
3.Native SQL query :
- session.createSQLQuery(
- "select {c.*} from CATEGORY {c} where NAME like 'Laptop%'"
- ).addEntity("c", Category.class);
最近,我在項(xiàng)目中經(jīng)常遇到Hibernate數(shù)據(jù)查詢的任務(wù),我對一些我遇到的較難的課題舉例進(jìn)行說明:《表述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結(jié)果》:
- Criteria crit = session.createCriteria(Cat.class);
- .setMaxResults(5)
- .list();
《分頁》:
- Criteria crit = session.createCriteria(Cat.class)
- .setFirstResult(1)
- .setMaxResults(50)
- .list();
《取查詢結(jié)果》:如果使用select或group,必須使用object[]來獲得查詢結(jié)果List值;
如果未使用select或group,必須使用java object[]來獲得查詢結(jié)果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聯(lián)合查詢》:
- SQLQuery query = session.createSQLQuery(“select activitylog_seq.nextval as sessid from dual”);
- Query.addScalar(“sessid”,Hibernate.LONG);
- Long long0 = query.uniqueResult();
以上介紹Hibernate Framework。
【編輯推薦】