createQuery 与 createNativeQuery 区别

本文探讨了iabernate中createQuery与createSQLQuery的区别,前者使用HQL查询并返回Hibernate Bean列表,而后者通过原生SQL查询返回对象数组。为了实现createSQLQuery也能返回Bean列表,文章提供了一个示例,展示了如何结合使用两种查询方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

iabernate 中createQuery与createSQLQuery区别,使用经验 
createQuery与createSQLQuery两者区别是: 


前者用的hql语句进行查询,后者可以用sql语句查询 

前者以hibernate生成的Bean为对象装入list返回 

后者则是以对象数组进行存储 
 

所以使用createSQLQuery有时候也想以hibernate生成的Bean为对象装入list返回

如下示例:

 

 


 
  1. @Override

  2. public List<Commodity> findCommodityByActyId(int activityId) {

  3. String sql = "SELECT aa.ACTIVITYSCOPE_VALUE from activity_scope aa LEFT JOIN activity_rule ar ON aa.ACTIVITYRULE_ID = ar.ACTIVITYRULE_ID LEFT JOIN"

  4. +" activity ac on ar.ACTIVITY_ID = ac.ACTIVITY_ID where ac.ACTIVITY_ID ="+activityId+" and ac.status=3";

  5. System.out.println(sql);

  6. Query query = entityManager.createNativeQuery(sql);

  7. List<Integer> commoditiyIds = (List<Integer>)(query.getResultList());

  8. List<Commodity> commodities = new ArrayList<Commodity>();

  9. for(int i=0;i<commoditiyIds.size();i++) {

  10. String sql2 = "from Commodity c where c.commodityId=:c1";

  11. Query query2 = entityManager.createQuery(sql2);

  12. query2.setParameter("c1", commoditiyIds.get(i));

  13. Commodity c = (Commodity) query2.getResultList().get(0);

  14. commodities.add(c);

  15. }

  16. return commodities;

  17. }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值