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基础查询语句的更多相关文章

  1. SQL Serever学习9——基础查询语句

    SQL语言概述 SQL是结构化查询语言(Structure Query Language),1974年提出,1979年被IBM实现,SQL语言已经成为关系型数据库的标准语言. 包括: DDL数据定义语 ...

  2. hql常用查询语句

    // HQL: Hibernate Query Language.// 特点:// >> 1,与SQL相似,SQL中的语法基本上都可以直接使用.// >> 2,SQL查询的是表 ...

  3. sql基础查询语句

    数据库文件百度云地址:www.pan.baidu.com 脚步:下载博客园文件:select_learn.rar 1.TOP限制返回行数[percent] * from book_info --显示前 ...

  4. PL/SQL第三章 基础查询语句

    --查询所有列 select * from tab_name|view_name; SELECT * FROM emp; SELECT * FROM (SELECT * FROM emp); --查询 ...

  5. oracle 基础查询语句

    select abs(10) from dual; --取绝对值select ceil(3.6) from dual;--向上取整 select power(2,3) from dual;--2的3次 ...

  6. JavaWeb_(Hibernate框架)Hibernate中数据查询语句HQL基本用法

    HQL(Hibernate Query Language) 是面向对象的查询语言, 它和 SQL 查询语言有些相似. 在 Hibernate 提供的各种检索方式中, HQL 是使用最广的一种检索方式. ...

  7. HQL查询语句

    查询语言 Hibernate 查询语言(HQL)是一种面向对象的查询语言,类似于 SQL,但不是去对表和列进行操作,而是面向对象和它们的属性. HQL 查询被 Hibernate 翻译为传统的 SQL ...

  8. 15个初学者必看的基础SQL查询语句

    本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...

  9. [原创]java WEB学习笔记90:Hibernate学习之路-- -HQL检索方式,分页查询,命名查询语句,投影查询,报表查询

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

随机推荐

  1. 一维Poisson方程计算

    package com.smartmap.algorithm.equation.differential.partial.ellipsoidal; import java.io.FileOutputS ...

  2. Mac下的Parallel Windows忘记密码怎么办?

    Mac机上安装了Parallel Windows,日久年深不登录结果忘记了登录密码,百爪挠心,想破脑壳试了n个密码都不行,放了一个多月也没想起来. 今天没事网上溜溜,肯定也有和我同病相怜的弟兄,果然, ...

  3. 【读书笔记】iOS网络-使用Game Kit实现设备间通信

    Apple的Game Kit框架可以实现没有网络状况下的设备与设备之间的通信,这包括没有蜂窝服务,无法访问Wi-Fi基础设施以及无法访问局域网或Internet等情况.比如在丛林深处,高速公路上或是建 ...

  4. IOS开发之Bug--关于C语言数组的容量参数

    这个错误之前没遇过,蛮奇葩的错误,只是一开始不了解,因为它折腾了许久. 先简单概括一下,以后有时间整理一下: 对应创建C语言的byte数组,我一开始使用:Byte b[PROTOCOL_CACHE_B ...

  5. Windows7下安装CentOS

    以CentOS为平台,配以其他软件共同组成工作平台! 第一部分:安装前准备        1. 准备两个fat32格式的分区,一个用于存放centos光盘镜像及相关安装程序,一个用于安装centos( ...

  6. 关于PHP的curl开启问题

    今天在做一个新浪登录功能,新浪提供的PHP SDK里需要用到curl_init()函数,在调试的时候报找不到curl_init()的方法. 经搜索得知需要开启curl的php扩展,那curl又是什么呢 ...

  7. Spring MVC 原理小结

    主要由DispatcherServlet.处理器映射.处理器.视图解析器.视图组成   1.DispatcherServlet接收到一个HTTP请求,根据对应配置文件中的处理机映射,找到处理器(Han ...

  8. 史上最详细“截图”搭建Hexo博客并部署到Github

    http://jingyan.baidu.com/article/d8072ac47aca0fec95cefd2d.html 大家也搭建过博客,很多时候,按着教程来做就可以了,但是我当时为了搭建Hex ...

  9. WPF学习之路(十)实例:用户注册

    通过一个注册用户的实例了解页面间数据的传递 首先构建一个User类  User.cs public class User { private string name; public string Na ...

  10. 开篇:IT软件人员学习的书籍 - IT软件人员书籍系列文章

    读书是一件快乐的事情. 读书能够增长知识,了解社会,了解人类的思想,继而转换成智慧.无论是什么人,都需要读书,多读书,读好书,同时也要把书中的精髓记录下来,一个是当做读后感,一个是为以后如果忘记了回头 ...