温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Hibernate Framework查询怎么实现

发布时间:2021-12-06 09:23:46 来源:亿速云 阅读:109 作者:iii 栏目:编程语言

本篇内容主要讲解“Hibernate Framework查询怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“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查询的延伸,提供了一些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);

最近,我在项目中经常遇到Hibernate数据查询的任务,我对一些我遇到的较难的课题举例进行说明:《表述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联合查询》:

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

到此,相信大家对“Hibernate Framework查询怎么实现”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI