JPQL查询

JPQL查询

1 jpql的介绍
sql:查询的是表和表中的字段。
jpql:查询的是实体类和类中的属性。
jpql和sql语句的语法相似。
JPQL全称Java Persistence Query Language
基于首次在EJB2.0中引入的EJB查询语言(EJB QL),Java持久化查询语言(JPQL)是一种可移植的查询语言,旨在以面向对象表达式语言的表达式,将SQL语法和简单查询语义绑定在一起•使用这种语言编写的查询是可移植的,可以被编译成所有主流数据库服务器上的SQL。
其特征与原生SQL语句类似,并且完全面向对象,通过类名和属性访问,而不是表名和表的属性。
2 查询全部
编写测试代码如下:

package com.txw.test;

import com.txw.utils.JpaUtils;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import java.util.List;
/**
 * 测试jqpl
 * @author: Adair
 */
@SuppressWarnings("all")         // 注解警告信息
public class JpqlTest {
    /**
     * 查询全部
     *      jqpl:from com.txw.domain.Customer
     *      sql:SELECT * FROM cst_customer
     */
    @Test
    public void testFindAll() {
        // 1.获取entityManager对象
        EntityManager em = JpaUtils.getEntityManager();
       // 获取事务对象
        EntityTransaction tx = em.getTransaction();
        // 2.开启事务
        tx.begin();
        // 3.查询全部
        String jpql = "from com.txw.domain.Customer";
        // 创建Query查询对象,query对象才是执行jqpl的对象
        Query query = em.createQuery(jpql);
        // 发送查询,并封装结果集
        List list = query.getResultList();
        for (Object obj : list) {
            System.out.println(obj);
        }
        // 4.提交事务
        tx.commit();
        // 5.释放资源
        em.close();
    }
}

运行结果如图所示:
在这里插入图片描述
3 排序
编写测试的代码如下:

package com.txw.test;

import com.txw.utils.JpaUtils;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import java.util.List;
/**
 * 测试jqpl
 * @author: Adair
 */
@SuppressWarnings("all")         // 注解警告信息
public class JpqlTest {
    /**
     * 排序查询: 倒序查询全部客户(根据id倒序)
     *      sql:SELECT * FROM cst_customer ORDER BY cust_id DESC
     *      jpql:from Customer order by custId desc
     * 进行jpql查询
     *      1.创建query查询对象
     *      2.对参数进行赋值
     *      3.查询,并得到返回结果
     */
    @Test
    public void testFindAll() {
        // 1.获取entityManager对象
        EntityManager em = JpaUtils.getEntityManager();
       // 获取事务对象
        EntityTransaction tx = em.getTransaction();
        // 2.开启事务
        tx.begin();
        // 3.查询全部
        String jpql = "from Customer order by custId desc";
        // 创建Query查询对象,query对象才是执行jqpl的对象
        Query query = em.createQuery(jpql);
        // 发送查询,并封装结果集
        List list = query.getResultList();
        for (Object obj : list) {
            System.out.println(obj);
        }
        // 4.提交事务
        tx.commit();
        // 5.释放资源
        em.close();
    }
}

运行结果如图所示:在这里插入图片描述
4 统计查询
编写测试的代码如下:

package com.txw.test;

import com.txw.utils.JpaUtils;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import java.util.List;
/**
 * 测试jqpl
 * @author: Adair
 */
@SuppressWarnings("all")         // 注解警告信息
public class JpqlTest {
    /**
     * 使用jpql查询,统计客户的总数
     *      sql:SELECT COUNT(cust_id) FROM cst_customer
     *      jpql:select count(custId) from Customer
     */
    @Test
    public void testCount() {
        // 1.获取entityManager对象
        EntityManager em = JpaUtils.getEntityManager();
       // 获取事务对象
        EntityTransaction tx = em.getTransaction();
        // 2.开启事务
        tx.begin();
        // 3.查询全部
        // 根据jpql语句创建Query查询对象
        String jpql = "select count(custId) from Customer";
        Query query = em.createQuery(jpql);
        // 对参数赋值
        // 发送查询,并封装结果
        /**
         * getResultList : 直接将查询结果封装为list集合
         * getSingleResult : 得到唯一的结果集
         */
        Object result = query.getSingleResult();
        System.out.println(result);
        // 4.提交事务
        tx.commit();
        // 5.释放资源
        em.close();
    }
}

运行结果如图所示:在这里插入图片描述
5 分页查询
编写测试的代码如下:

package com.txw.test;

import com.txw.utils.JpaUtils;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import java.util.List;
/**
 * 测试jqpl
 * @author: Adair
 */
@SuppressWarnings("all")         // 注解警告信息
public class JpqlTest {
    /**
     * 分页查询
     *      sql:select * from cst_customer limit 0,2
     *      jqpl : from Customer
     */
    @Test
    public void testPaged() {
        // 1.获取entityManager对象
        EntityManager em = JpaUtils.getEntityManager();
       // 获取事务对象
        EntityTransaction tx = em.getTransaction();
        // 2.开启事务
        tx.begin();
        // 3.查询全部
        // 根据jpql语句创建Query查询对象
        String jpql = "from Customer";
        Query query = em.createQuery(jpql);
        // 对参数赋值 -- 分页参数
        // 起始索引
        query.setFirstResult(0);
        //每页查询的条数
        query.setMaxResults(2);
        // 发送查询,并封装结果
        /**
         * getResultList : 直接将查询结果封装为list集合
         * getSingleResult : 得到唯一的结果集
         */
        List list = query.getResultList();
        for(Object obj : list) {
            System.out.println(obj);
        }
        // 4.提交事务
        tx.commit();
        // 5.释放资源
        em.close();
    }
}

运行结果如图所示:在这里插入图片描述
6 条件查询
编写测试的代码如下:

package com.txw.test;

import com.txw.utils.JpaUtils;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import java.util.List;
/**
 * 测试jqpl
 * @author: Adair
 */
@SuppressWarnings("all")         // 注解警告信息
public class JpqlTest {
    /**
     * 条件查询
     *     案例:查询客户名称以‘学无止路’开头的客户
     *          sql:SELECT * FROM cst_customer WHERE cust_name LIKE  ?
     *          jpql : from Customer where custName like ?
     */
    @Test
    public void testCondition() {
        // 1.获取entityManager对象
        EntityManager em = JpaUtils.getEntityManager();
       // 获取事务对象
        EntityTransaction tx = em.getTransaction();
        // 2.开启事务
        tx.begin();
        // 3.查询全部
        // 根据jpql语句创建Query查询对象
        String jpql = "from Customer where custName like ? ";
        Query query = em.createQuery(jpql);
        // 对参数赋值 -- 占位符参数
        //第一个参数:占位符的索引位置(从1开始),第二个参数:取值
        query.setParameter(1,"学无止路%");
        // 发送查询,并封装结果
        /**
         * getResultList : 直接将查询结果封装为list集合
         * getSingleResult : 得到唯一的结果集
         */
        List list = query.getResultList();
        for(Object obj : list) {
            System.out.println(obj);
        }
        // 4.提交事务
        tx.commit();
        // 5.释放资源
        em.close();
    }
}

运行结果如图所示:在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学无止路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值