本文主要介绍在Hibernate Framework中的三种查询数据的方式,下面就三种方式一一举例,希望大家阅读后有很大的收益。
成都创新互联公司-专业网站定制、快速模板网站建设、高性价比中原网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式中原网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖中原地区。费用合理售后完善,十多年实体公司更值得信赖。
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。
【编辑推荐】
文章题目:Hibernate Framework查询实例
网站链接:http://www.csdahua.cn/qtweb/news39/294489.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网