国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 編程設(shè)計(jì) > 正文

Hibernate高級(jí)查詢(xún)實(shí)戰(zhàn)

2023-06-11 14:56:25
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

大家知道,在Hibernate Framework中,提供了三種查詢(xún)數(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查詢(xún)的延伸,提供了一些高級(jí)查詢(xún)功能
例:
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);

最近,我在項(xiàng)目中經(jīng)常遇到Hibernate數(shù)據(jù)查詢(xún)的任務(wù),我對(duì)一些我遇到的較難的課題舉例進(jìn)行說(shuō)明:

《表述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();

《分頁(yè)》:
Criteria crit = session.createCriteria(Cat.class)
.setFirstResult(1)
.setMaxResults(50)
.list();

《取查詢(xún)結(jié)果》:
如果使用select或group,必須使用object[]來(lái)獲得查詢(xún)結(jié)果List值;
如果未使用select或group,必須使用java object[]來(lái)獲得查詢(xún)結(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)合查詢(xún)》:
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();

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 嵊泗县| 介休市| 当雄县| 子长县| 彰化县| 永登县| 突泉县| 昭觉县| 宜兴市| 侯马市| 恩平市| 深州市| 恩施市| 久治县| 金湖县| 乌拉特前旗| 克什克腾旗| 方山县| 晋宁县| 康平县| 岗巴县| 沁阳市| 秦皇岛市| 突泉县| 茶陵县| 福贡县| 曲周县| 平果县| 定日县| 涿州市| 东山县| 德庆县| 长垣县| 广南县| 东山县| 琼中| 玛曲县| 潞城市| 绥滨县| 湘潭县| 奉节县|