Hibernate查询语句

本文介绍了HQL查询的基础语法,包括实体对象查询、动态实例化对象查询等,并详细讲解了条件查询、日期时间处理、连接查询、聚合函数及子查询的应用。

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

1 HQL的基本语法

    select "属性名" from "对象" 

    where "条件"

    group by "属性名" having "分组条件"

    order by "属性名" desc / asc

2 实体对象查询

   from User

3 动态实例化对象查询

   select new User(id, name) from User

4 条件查询与别名

   from User where id = 1

   from User u where u.id = 1

   from User as u where u.id = 1

5 HQL语句的动态赋值

   String hql = "from User u where u.id = ?";

   Query query = session.createQuery(hql);

   query = query.setParameter(0,3);

   list = query.list();

   自定义参数名称

   String hql = "from User u where u.id = :userId";

   query = query.setParameter("userId",3);

6 对日期时间的处理

   String hql = "from User u where date_format(u.birth,'%Y-%m') = ?";

   Query query = session.createQuery(hql).setParameter(0,"1984-01");

7 join(内连接),left join,rigth join,full join(全连接)

   from Student s left join s.classes c with c.id > 10;

8 聚合函数 select count(*) from User u;

                    select max(u.id) from User u;

9 子查询 

   String hql = "select med.name from Medicine med where med.price = (select max(price) from Medicine)";

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值