Hibernate HQL语句总结

认识HQL


一个ORM框架是建立在面向对象的基础上的。最好的例子是Hibernate如何提供类SQL查询。虽然HQL的语法类似于SQL,但实际上它的查询目标是对象。HQL拥有面向对象语言的所有的特性,这其中包括多态、继承和组合。这就相当于一个面向对象的SQL。


HQL(Hibernate Query Language)它对查询条件进行了面向对象封装,符合编程人员的思维方式。同时也提供了类似标准SQL语句的查询方式。

使用HQL

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。


简单使用:

from User user where user age=20;
from User user where user age between 20 and 30;
from User user where user age in(20,30);
from User user where user name is null;
from User user where user name like ‘%zx%’;
from User user where (user age%2)=1;
from User user where user age=20 and user name like ‘%zx%’;
select user name,user age from User user 
update User user set user age=20 where user age=18
delete from User user where user age=18

结合spring boot:

使用的时候,主要在Reporsitory的接口中设计查询函数

@Query("select o from User o where o.userID= :userId and o.age between :start and :end" )
Page<User> Search(@Param("userID")String userId,@Param("start")Date start, @Param("end")Date end,Pageable p);

注意使用in查询的时候要加个括号,否则在执行的时候可能会出异常。

@Query("select o from User o where o.userID in (:userIds) and o.age between :start and :end" )
Page<User> Search(@Param("userIds")Iterable<String> userIds,@Param("start")Date start, @Param("end")Date end,Pageable p);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值