HQL基础查询语句
HQL基础查询语句
1.使用hql语句检索出Student表中的所有列
//核心代码
@Test
public void oneTest()
{
Query query=session.createQuery("form Student");
List<Student> list=query.list();
for(Student item:list)
{
System.out.println(item.getName());
}
}
2.使用hql语句语句检索出部分列
//核心代码
@Test
public void twoTest()
{
Query query=session.createQuery("select name from Student");
List<String> list=query.list();
for(String item:list)
{
System.out.println(item);
}
}
3.使用hql语句检索出多列
//核心代码
@Test
public void threeTest()
{
Query query=session.createQuery("select name,age from Student");
List<Object[]> list=query.list();
for(Object[] item : list)
{
System.out.println(item[0]+"\t"+item[1]);
}
}
4.投影出多列,有构造植入,返回强类型
//核心代码
@Test
public void fourTest()
{
Query query=session.createQuery("select Student(id,name,age) from Student");//Student(id,name,age)和实体类带参构造顺序相同
List<Student> list=query.list();
for(Student item:list)
{
System.out.println(item.getName());
}
}
5.带条件查询,匿名占位符
//核心代码
@Test
public void fiveTest()
{
Query query=session.createQuery("select Student from Student where name=?");
query.setParameter(0,"王小三");
List<Student> list=query.list();
for(Student item:list)
{
System.out.println(item.getName());
}
}
6.带条件查询,名称占位符
//核心代码
@Test
public void SixTest()
{
Query query = session.createQuery("select Student from Student where stu.sname=:name");
query.setParameter("name", "王小四");
List<Student> list=query.list();
for (Student item : list) {
System.out.println(item.getSid());
}
}
7.动态查询,需要新建一个工具类,用到几个属性就封装几个属性
public class StudentCondition {
private String name;
private Integer age;
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
//测试类核心代码
StudentCondition condition=new StudentCondition();
condition.setAge(25);
condition.setName(null);
StringBuilder sb=new StringBuilder();
sb.append("from Student where 1=1 ");
Student stu=new Student();
if(condition.getAge()!=null)
{
sb.append(" and sage=:sage");
stu.setSage(condition.getAge());
}
if(condition.getName()!=null)
{
sb.append(" and sname=:sname");
stu.setSname(condition.getName());
}
Query query = session.createQuery(sb.toString());
query.setProperties(stu);
List<Student> list=query.list();
for (Student item : list) {
System.out.println(item.getSname());
}//投影出年龄25岁的学生信息
}
8.分页查询数据
@Test
public void nineTest()
{
String sql="from Student";
Query query = session.createQuery(sql);
Integer pageIndex=1;
Integer pageSize=2;
query.setFirstResult((pageIndex-1)*pageSize);
query.setMaxResults(pageSize);
List<Student> list = query.list();
for (Student student : list) {
System.out.println(student);
}
HQL基础查询语句的更多相关文章
- SQL Serever学习9——基础查询语句
SQL语言概述 SQL是结构化查询语言(Structure Query Language),1974年提出,1979年被IBM实现,SQL语言已经成为关系型数据库的标准语言. 包括: DDL数据定义语 ...
- hql常用查询语句
// HQL: Hibernate Query Language.// 特点:// >> 1,与SQL相似,SQL中的语法基本上都可以直接使用.// >> 2,SQL查询的是表 ...
- sql基础查询语句
数据库文件百度云地址:www.pan.baidu.com 脚步:下载博客园文件:select_learn.rar 1.TOP限制返回行数[percent] * from book_info --显示前 ...
- PL/SQL第三章 基础查询语句
--查询所有列 select * from tab_name|view_name; SELECT * FROM emp; SELECT * FROM (SELECT * FROM emp); --查询 ...
- oracle 基础查询语句
select abs(10) from dual; --取绝对值select ceil(3.6) from dual;--向上取整 select power(2,3) from dual;--2的3次 ...
- JavaWeb_(Hibernate框架)Hibernate中数据查询语句HQL基本用法
HQL(Hibernate Query Language) 是面向对象的查询语言, 它和 SQL 查询语言有些相似. 在 Hibernate 提供的各种检索方式中, HQL 是使用最广的一种检索方式. ...
- HQL查询语句
查询语言 Hibernate 查询语言(HQL)是一种面向对象的查询语言,类似于 SQL,但不是去对表和列进行操作,而是面向对象和它们的属性. HQL 查询被 Hibernate 翻译为传统的 SQL ...
- 15个初学者必看的基础SQL查询语句
本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...
- [原创]java WEB学习笔记90:Hibernate学习之路-- -HQL检索方式,分页查询,命名查询语句,投影查询,报表查询
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
随机推荐
- javascript对象初探(一)--- 构造器函数
我们可以通过构造器函数(简称构造函数)来创建对象: function Her(){ this.child = 'Jon'; } 为了使用该函数来创建对象,我们需要使用new操作符,例如: var sh ...
- 记STM32F030多通道ADC DMA读取乱序问题
问题描述通过 uint16_t ConvData[8]保存DMA搬运的ADC转换数值,但是这个数组数值的顺序总是和ADC不是顺序对应的.比如用7个通道的ADC,当设置ADC_InitStructure ...
- JavaScript上传图片及时预览
/*******************************正面图片上传预览开始****************************/ function previewImage ...
- No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=x86_64, VALID_ARCHS=i386)
今天在运行一个老ios项目的时候,突然报错:No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=x86_64, VAL ...
- XCode模拟器上下黑边、显示不完整、适配问题
其实出现上下黑边是因为iOS默认将启动时的LaunchImage的宽高当成程序的宽高,所以启动图片如果只有小屏的图片,那么就会出现大屏状态下屏幕不能满屏的错误. 解决方法: 添加所有尺寸屏幕的Laun ...
- C语言中的函数与指针
1. 为什么需要函数? 函数就是功能的封装. 函数就是为了实现某个功能而编写的一段代码 scanf() , printf() 2.函数优点: 代码更简洁 代码复用 如果业务逻辑变化,只把相应的 ...
- IOS开发证书显示“此证书的签发者无效”解决方法
今天早上同事说咱们的证书无法使用了,显示“此证书的签发者无效”.一开始以为谁误操作了证书,查看后发现所有证书都无效了.查了会才发下原来是Apple Worldwide Developer Relati ...
- Java是如何处理别名(aliasing)的
什么是Java别名(aliasing) 别名意味着有多个别名指向同一个位置,且这些别名有不同的类型. 在下面的代码例子中,a和b是两个不同的名字,有不同的类型A和B,B继承A B[] b = new ...
- SSH框架搭建详解 及 乱码处理
http://www.360doc.com/content/15/1031/21/21693298_509739569.shtml struts 除了struts的mvc外,还有拦截器,国际化,str ...
- CDC 2013 北京站手记
受搜狐畅游的邀请,这次能够有机会参与2013中国开发者大会北京站的活动. 本次大会的主题是“游戏”和“移动”,因此上午的峰会安排了5个主讲,分别就搜索.云存储服务器.游戏媒体.移动应用和游戏渠道等多方 ...