hql


https://mp.weixin.qq.com/s?__biz=MzUxNDMyOTU4NQ==&mid=2247484301&idx=1&sn=c0a511454fb6e18fb5ea9be01fae5aaa&chksm=f946dd13ce315405c0ffdebd018dc91de01e3335bb365eedb5f0ae8cbc164260288aea94aab8&mpshare=1&scene=1&srcid=0327wmCoBRKDqJKRTnxss7Sa&key=353b6d2bc73260270af84b206f164a238700e1b02cdbaa20e4caaba598c72745be772f7492500d7f69c31bacc6127e783084db435ade376e3bd72ed358e37e7fb98e3d31e5fb0888f05c6dc49b1c7d20&ascene=0&uin=MTA2NzUxMDAyNQ%3D%3D&devicetype=iMac+MacBookAir6%2C2+OSX+OSX+10.10.5+build(14F2511)&version=11020012&lang=zh_CN&pass_ticket=YOhvdyFJYno3pJPXiaSEWxhPrymv49PNwcVMB6NeX3FSIg%2FYjhsf%2FN9wmUt57lX5



HQL


HQL是Hibernate Query Language的缩写,提供更加丰富灵活、更为强大的查询能力;HQL更接近SQL语句查询语法。


HQL与SQL


上面已经说过HQL是一种更为接近SQL的查询语法,那么我们来看一看SQL和HQL什么区别。


  • 普通查询


    sql:select * from user;

    hql:from User;



从语句中我想大家应该可以看出来SQL与HQL最大的差别。SQL是面向表单进行查询;HQL是面向反向生成的Java Bean进行查询。HQL的书写方式更加接近于面向对象的写法。


  • 带参数的查询


    占位符:

       sql:select * from user where id = ?;

       hql:from User where id= ?;


在这里HQL的写法与jdbc中的预处理模式一样,不过在HQL中的ID并不是表单中的ID,而是User类中的私有属性id。


注意Hibernate中的占位符从0开始,Jdbc从1开始。


       参数查询:

       hql:from User where id= :id;

       hql:from User where id in(:ids);


这里是一种参数的查询方式,其实与占位符的意思差不太多。


  • 查询一部分数据集


    sql:select name,age from user ;

       hql:select new User(name,age) from User;


这里的name和age代表着映射出来的User类中的name属性和age属性。这样子有个很大的好处就是不需要把查询出来的Object再此进行转换,hibernate已经帮你转换好了。


HQL存放位置


HQL可以写在程序调用之时,也可以预先写hbm.xml文件中。

<query name="queryUserRanage">
   FROM User WHERE id BETWEEN ? AND ?
</query>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值