前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >hql查询语句用法详解_sql add语句

hql查询语句用法详解_sql add语句

作者头像
全栈程序员站长
发布于 2022-11-11 07:11:22
发布于 2022-11-11 07:11:22
1K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

HQL的语法比较简单,与普通SQL的区别之处是针对对象的不同,在查询语句中将sql中的表名替换成了sql中的持久化类名,因为hibernate机制是基于对象进行查询的。

不带参数的查询,语句是“from POJO”的形式,其中POJO即为持久化类名称

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Query query=session.createQuery("from User");

带参数的查询

接口Query提供了对命名参数、JDBC风格的(?)两种参数的绑定方法。

命名参数在查询字符串中是形如name的标识符。

命名参数的优点:

1、命名参数与其在查询串中出现的顺序无关。

2、它们可在同一查询串中多次出现。

3、它们本身是自我说明的。

命名参数的使用格式是 :username /* username这里泛指命名参数名 */

赋值采用: Query的setXXX()f方法。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/* 这是使用一个命名参数username,然后给命名参数设置值为“admin”的例子*/
Query query=session.createQuery("from User where username=:username");
query.setString("username","admin");
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/* 使用集合类型的命名参数的例子 */
List names=new ArrayList();
names.add("admin");
names.add("test");
Query query=session.createQuery("from User where username in (:nameList)");
query.setParameterList("nameList",names);

hibernate使用问号参数时与JDBC不同,hibernate对参数从0开始计数。JDBC应该是从0开始的

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Query query=session.createQuery("from User where username=?");
query.setString(0,"admin");

在HQL语句中可以设置多个问号参数,之后按照”0、1、2、3…”的序号形式来设置各个参数的值。

取读query中的值:

1、将query中的值转换成list然后进行后面的操作

query.list()方法。

demo:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public List<Person> hqlquerylist(String hql){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=session.beginTransaction();
        List<Person> p = null;
        try{
        Query query=session.createQuery(hql);
        p=query.list();
        tx.commit();
        }catch(Exception e){
            e.printStackTrace();
            tx.rollback();
        }
        return p;
    }

View Code

2、将query中的值转换成iterator对象然后进行后面的操作

1)query.iterator()方法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public Iterator<Person> hqlqueryiterator(String hql){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=session.beginTransaction();
        Iterator<Person> p = null;
        try{
        Query query=session.createQuery(hql);
        p=query.iterate();
        tx.commit();
        }catch(Exception e){
            e.printStackTrace();
            tx.rollback();
        }finally{
            session.clear();
        }
        return p;
    }

View Code

2)、将query.list()得到的对象转换称为iterator对象

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public Iterator<Person> hqlqueryiterator(String hql){
        session=HibernateSessionFactory.getSession();
        Transaction tx=session.beginTransaction();
        Iterator<Person> p = null;
        try{
        Query query=session.createQuery(hql);
        //p=query.iterate();
        p=query.list().iterator();
        tx.commit();
        }catch(Exception e){
            e.printStackTrace();
            tx.rollback();
        }/*finally{
            session.close();
        }*/
        return p;
    }

View Code

3、当已知query中的对象为0个或者1个的时候,可以使用uniqueResult()取得一个对象。

返回:单个实例或者null 抛出:当返回的实例大于一个的时候的抛出NonUniqueResultException

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public Person queryUniqueResult(int id){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=session.beginTransaction();
        Person p = null;
        try{
        Query query=session.createQuery("from Person where id=:id");
        query.setInteger("id", id);
        p=(Person) query.uniqueResult();
        tx.commit();
        }catch(Exception e){
            e.printStackTrace();
            tx.rollback();
        }/*finally{
            session.close();
        }*/
        return p;
    }

View Code

4、标量查询

查询可以在select语句中指定类的属性,甚至可以调用SQL统计函数。统计结果或者属性被称为“标量Scalar”的结果。

demo:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public static void main(String[] args){
        PersonDAO persondao=new PersonDAO();
        String hql="select P.name,count(P.address) from Person P";
        Iterator<Object[]> it=persondao.hqlqueryScalar(hql);
        while(it.hasNext()){
            Object[] o=it.next();
            System.out.println(o[0]+"\t"+o[1]);
        }
    }
public Iterator<Object[]> hqlqueryScalar(String hql){
        session=HibernateSessionFactory.getSession();
        Transaction tx=session.beginTransaction();
        Iterator<Object[]> p = null;
        try{
        Query query=session.createQuery(hql);
        //p=query.iterate();
        p=query.list().iterator();
        tx.commit();
        }catch(Exception e){
            e.printStackTrace();
            tx.rollback();
        }/*finally{
            session.close();
        }*/
        return p;
    }

View Code

5、分页查询

我们知道,sqlserver的查询使用的是top,mysql使用的是limit,oracle使用的是rownumber。

其实hibernate有快捷的分页查询方式,框架可以自动生成对应的分页查询语句。

使用query对象的setFirstResult()和对象的setMaxResult()设置查询的起始指针和查询的最大数量,再使用query的其他取出对象方法得到想要的值。hibernate自动生成sql查询语句。

注意:指针是从0开始的。也就是指针为0的对应数据库中的第一条记录。

demo:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public Iterator<Student> queryhql(String hql,int first,int max){
        session=HibernateSessionFactory.getSession();
        
        Query query=session.createQuery(hql);
        query.setFirstResult(first);
        query.setMaxResults(max);
        Iterator<Student> s=query.list().iterator();
        return s;
    }
StudentDAO studentdao=new StudentDAO();
        String hql="from Student";
        int first=1;
        int max=2;
        Iterator<Student> s=studentdao.queryhql(hql, first, max);
        while(s.hasNext()){
            Student stu=s.next();
            System.out.println(stu.getName()+"\t"+stu.getAge()+"\t"+stu.getSex()+"\t"+stu.getTelephone());
        }

View Code

SQL语句查询

使用createSQLQuery()方法,然后在后面加上addEntity()

demo:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public static void main(String[] args){
        String sql="select * from student where age=:age and name=:name";
        Session session=HibernateSessionFactory.getSession();    
            SQLQuery sqlquery=session.createSQLQuery(sql).addEntity(Student.class);
            sqlquery.setString("name", "guozhen");
            sqlquery.setInteger("age", 21);
            List<Student> s=sqlquery.list();
            Student stu=s.get(0);
            System.out.println(stu.getName()+"\t"+stu.getAge()+"\t"+stu.getId()+"\t"+stu.getTelephone()+"\t"+stu.getTelephone());
        
    }

View Code

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/187662.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月29日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
JUC并发—7.AQS源码分析三
volatile、synchronized、CAS、AQS、读写锁、锁优化和锁故障、并发集合、线程池、同步组件
东阳马生架构
2025/04/27
70
Java多线程之---用 CountDownLatch 说明 AQS 的实现原理
前面的文章中说到了 volatile 以及用 volatile 来实现自旋锁,例如 java.util.concurrent.atomic 包下的工具类。但是 volatile 的使用场景毕竟有限,很多的情况下并不是适用,这个时候就需要 synchronized 或者各种锁实现了。今天就来说一下几种锁的实现原理。
古时的风筝
2018/07/31
8680
Java多线程之---用 CountDownLatch 说明 AQS 的实现原理
AbstractQueuedSynchronizer 原理分析 - 独占/共享模式
AbstractQueuedSynchronizer (抽象队列同步器,以下简称 AQS)出现在 JDK 1.5 中,由大师 Doug Lea 所创作。AQS 是很多同步器的基础框架,比如 ReentrantLock、CountDownLatch 和 Semaphore 等都是基于 AQS 实现的。除此之外,我们还可以基于 AQS,定制出我们所需要的同步器。
田小波
2018/05/02
3.7K11
AbstractQueuedSynchronizer 原理分析 - 独占/共享模式
AQS之共享锁
通过 AQS独占锁,我们对AQS的数据结构有了基本的了解。它本质上就是一个优化过的CLH队列,因为CLF队列只有一个前驱指针,而AQS除了前驱指针,还有一个后驱指针。先简单总结一个AQS的特性
spilledyear
2020/01/02
7050
一文搞懂 CountDownLatch 用法和源码!
CountDownLatch 是多线程控制的一种工具,它被称为 门阀、 计数器或者 闭锁。这个工具经常用来用来协调多个线程之间的同步,或者说起到线程之间的通信(而不是用作互斥的作用)。下面我们就来一起认识一下 CountDownLatch
cxuan
2021/01/06
1.3K0
老司机发车了,CountDownLatch:到底等不等你呀
前几天我们把 ReentrantLock的原理 进行了详细的讲解,不熟悉的同学可以翻看前文,今天我们介绍另一种基于 AQS 的同步工具——CountDownLatch。
阿Q说代码
2023/01/09
1980
老司机发车了,CountDownLatch:到底等不等你呀
JUC学习笔记——并发工具JUC
我们的AQS需要采用继承方法才能够实现(默认抛出 UnsupportedOperationException):
秋落雨微凉
2022/11/22
4260
JUC学习笔记——并发工具JUC
CountDownLatch
CountDownLatch是一个同步工具类,它使得一个或多个线程一直等待,直至其他线程的操作执行完成后再接着执行。在Java并发中,CountDownLatch是一个常见的面试题。
黑洞代码
2021/01/14
4040
CountDownLatch
AQS
AQS全称是AbstractQueuedSynchronizer,形如其名,抽象队列同步器。
在下是首席架构师
2022/08/01
3110
啰里吧嗦CountDownLatch
CountDownLatch是一个同步工具类,它允许一个或多个线程一直等待,直到其他线程的操作执行完后再执行
葫芦娃
2019/04/12
1.5K0
啰里吧嗦CountDownLatch
快速掌握并发编程---CountDownLatch原理和实战
如何实现让主线程等所有子线程执行完了后,主要线程再继续执行?即如何实现一个线程等其他线程执行完了后再继续执行?
田维常
2020/11/03
3750
快速掌握并发编程---CountDownLatch原理和实战
一文读懂Java并发编程之AQS
AbstractQueuedSynchronizer是一个双端队列,元素可以从队首进出,也可以从队尾进出,下面是AbstractQueuedSynchronizer 的成员变量,后面我们就叫 AbstractQueuedSynchronizer 为AQS。
小四的技术之旅
2022/07/26
5310
一文读懂Java并发编程之AQS
理解AbstractQueuedSynchronizer提供的独占锁和共享锁语义
Doug Lea前辈在JDK5中编写的AbstractQueuedSynchronizer抽象同步框架非常精辟,整个代码里没有使用像synchronized这样调用底层硬件系统层面的锁指令来实现同步状态管理,完全是使用Java语言层面功能配合上轻量级的CAS自旋锁来构建的抽象同步器,总的来说AQS里面包含了二套api语义一种是独占锁,另一种是共享锁。这两套语义都是独立的,并不是说任何时候我们都需要同时使用这两种功能的。关于AQS的学习不建议一上去就关注AQS类源码本身,因为单看源码看不出来有任何精妙,反而容易让人迷惑,但是我们从其构建的工具类反看其如何使用AQS功能,结合具体案例则更容易理解。
我是攻城师
2018/09/30
9670
理解AbstractQueuedSynchronizer提供的独占锁和共享锁语义
CountDownLatch 源码浅析
CountDownLatch 介绍 CountDownLatch是一个同步协助类,允许一个或多个线程等待,直到其他线程完成操作集。 CountDownLatch使用给定的计数值(count)初始化。await方法会阻塞直到当前的计数值(count)由于countDown方法的调用达到0,在这之后(即,count为0之后)所有等待的线程都会被释放,并且随后对await方法的调用都会立即返回。这是一个一次性现象 ———— count不会被重置。如果你需要一个重置count的版本,那么请考虑使用CyclicBar
tomas家的小拨浪鼓
2018/06/27
6460
高并发编程-CountDownLatch深入解析
CountDownLatch允许一个或者多个线程一直等待,直到一组其它操作执行完成。在使用CountDownLatch时,需要指定一个整数值,此值是线程将要等待的操作数。当某个线程为了要执行这些操作而等待时,需要调用await方法。await方法让线程进入休眠状态直到所有等待的操作完成为止。当等待的某个操作执行完成,它使用countDown方法来减少CountDownLatch类的内部计数器。当内部计数器递减为0时,CountDownLatch会唤醒所有调用await方法而休眠的线程们。
JavaQ
2018/07/26
7360
高并发编程-CountDownLatch深入解析
Java并发编程之CountDownLatch源码解析
最近在学习并发编程原理,所以准备整理一下自己学到的知识,先写一篇CountDownLatch的源码分析,之后希望可以慢慢写完整个并发编程。
周同学
2019/08/29
6140
Java并发编程之CountDownLatch源码解析
AbstractQueuedSynchronizer 源码分析(共享锁)
在AbstractQueuedSynchronizer中使用LockSupport类来实现线程的挂起和唤醒,对应方法分别我park和unpark,内部实现原理是代理给了unsafe包的park和unpark
Dylan Liu
2019/07/01
6320
多线程进阶——JUC并发编程之CountDownLatch源码一探究竟?
JDK的并发包中提供了几个非常有用的并发工具类。 CountDownLatch、 CyclicBarrier和 Semaphore工具类提供了一种并发流程控制的手段。本文将介绍CountDownLatch(闭锁)的实现原理。在了解闭锁之前需要先了解AQS,因为CountDownLatch的实现需要依赖于AQS共享锁的实现机制。
须臾之余
2021/07/27
3610
一篇文章让你掌握 AQS 核心知识
感谢原作者,本文转载自 https://my.oschina.net/xiongying0214/blog/1944627
好好学java
2019/07/01
5540
一篇文章让你掌握 AQS 核心知识
硬核的AQS
Java多线程在对共享资源进行访问时,如果不加以控制会存在线程安全问题,当我们使用多线程对共享资源访问时,通常会线程共享资源的进行访问线程数的控制:
shysh95
2021/04/07
2950
硬核的AQS
相关推荐
JUC并发—7.AQS源码分析三
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档