Hibernate在HQL中查询的方法有哪些
发表于:2025-11-10 作者:千家信息网编辑
千家信息网最后更新 2025年11月10日,本篇内容介绍了"Hibernate在HQL中查询的方法有哪些"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有
千家信息网最后更新 2025年11月10日Hibernate在HQL中查询的方法有哪些
本篇内容介绍了"Hibernate在HQL中查询的方法有哪些"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
1、支持字符串方式参数传递查询:
例子:
List students = session.createQuery("select s.id,s.name from Student s where s.name like '%1' ").list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] o = (Object[])iter.next(); System.out.println(o[0]+","+o[1]); }由于,涉及到多个属性查询,所以返回的是Object数组类型。
2、支持类似于PrepareStatement方式的?传递参数查询
例子:
List students = session.createQuery("select s.id,s.name from Student s where s.name like :goodname ") .setParameter("goodname", "%1%").list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] o = (Object[])iter.next(); System.out.println(o[0]+","+o[1]); }要设置参数从0开始,见第2行。
3、去变量方式参数传递
例子:
List students = session.createQuery("select s.id,s.name from Student s where s.name like :goodname ") .setParameter("goodname", "%1%").list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] o = (Object[])iter.next(); System.out.println(o[0]+","+o[1]); }这个跟2中的相似,只是多了参数可以归为一类。
4、支持多参数传递
例子:
List students = session.createQuery("select s.id, s.name from Student s where s.id in(:myids)") .setParameterList("myids", new Object[]{1, 2, 3, 4, 5,32,13,14}) .list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] o = (Object[])iter.next(); System.out.println(o[0]+","+o[1]); }注意调用方法是setParameterList。
5、调用数据库里面的函数
例子:
List students = session.createQuery("select s.id, s.name from Student s where date_format(s.createTime, '%Y-%m')=?") .setParameter(0, "2008-10") .list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] o = (Object[])iter.next(); System.out.println(o[0]+","+o[1]); }数据库函数date_format。
6、直接支持sql查询
例子:
List students = session.createSQLQuery("select *from t_student").list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] o = (Object[])iter.next(); System.out.println(o[0]+","+o[1]); }只需要调用session里面的createSQLQuery方法即可。
7、进行导航查询
例子:
List students = session.createQuery("select s.name from Student s where s.classes.name like '%1%'").list(); for (Iterator iter=students.iterator(); iter.hasNext();) { String s = (String)iter.next(); System.out.println(s); }这种查询很方便。
8、分页查询
例子:
List students = session.createQuery("from Student").setFirstResult(0).setMaxResults(3).list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Student student = (Student)iter.next(); System.out.println(student.getName()); }这是很简单的分页查询,分页查询实现比这个复杂多了,分页查询采用的相当于数据库里面的 limit ,来限制一次查询显示的条数。
"Hibernate在HQL中查询的方法有哪些"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
查询
例子
参数
方法
支持
数据
方式
内容
函数
更多
知识
面的
库里
复杂
实用
相似
学有所成
接下来
变量
只是
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
湖州网络技术有效果吗
信息安全服务器图片
软件开发入门教程
定期开展网络安全检测情况台账
将数据库拷贝到另一台机器上
1.网络安全的定义
山东省内疫情数据库
西安软件开发的公司有哪些
丰台科技园互联网公司地址
新泰市亮点网络技术
深耕互联网木链科技
网络安全各个协议名称解释
夸克苹果服务器暂时访问
数据库多表链接
腾讯云访问服务器上的文件
国家网络安全宣传作文题目
软件开发适合什么人群学习
数据库原理五大关系范式
数据库鼠标选不了空的地方
软件开发企业的资质级别
mc服务器图解
服务器租用一般多少钱
网络安全需学习哪些课程
戴尔小型服务器
少先队组织信息数据库每周课时数
电竞学校学软件开发视频
京东商城的数据库设计
达梦数据库无效的数据库对象
数据库鼠标选不了空的地方
银行服务器操作系统