1. 获取查询结果

2. JPQL函数和JPQL表达式

#1. 使用from子句

#2. 查询部分属性

#3. 查询中使用构造器

3. JPQL的关联查询和多态查询

#1. 多态查询

#2. 隐式连接

#3. 显式连接

4. 对查询结果集进行分页

5. 使用JPQL子查询和命名查询

#1. 子查询

#2. 命名查询

6. JPQL的批量更新和删除

#1. 批量更新

#2. 批量删除

--------------------------------------------------

1. 获取查询结果(Net Beans创建Java Project, 项目名称:JpqlQs)

JpaQs.java

package lee;

import java.util.List;
import javax.persistence.*; import org.crazyit.model.*; public class JpaQs { private static final EntityManagerFactory emf = Persistence.createEntityManagerFactory("qs"); public static void main(String[] args) {
EntityManager em = emf.createEntityManager();
try {
em.getTransaction().begin();
Query query = em.createQuery("select news , news.title , news.content"
+ " from News as news where news.id > ?1 and"
+ " news.title not like :title"); List result = query.setParameter(1, 1).setParameter("title", "%Java%").getResultList();
for (int i = 0; i < result.size(); i++) {
Object[] row = (Object[]) result.get(i);
for (int j = 0; j < row.length; j++) {
System.out.println(row[j]);
}
}
em.getTransaction().commit();
}
finally {
em.close();
}
}
}

News.java(参见12.2)

persistence.xml(参见12.2)

2. JPQL函数和JPQL表达式

#1. 使用from子句(Net Beans创建Java Project, 项目名称:From)

JpaQs.java

package lee;

import java.util.List;
import javax.persistence.*; import org.crazyit.model.*; public class JpaQs { private static final EntityManagerFactory emf = Persistence.createEntityManagerFactory("qs"); public static void main(String[] args) {
EntityManager em = emf.createEntityManager();
try {
em.getTransaction().begin();
Query query = em.createQuery("from News as news where news.id < ?1"
+ " and news.title like :title"); List result = query.setParameter(1, 8).setParameter("title", "%Java%").getResultList(); for (int i = 0; i < result.size(); i++) {
News news = (News) result.get(i);
System.out.println(news.getTitle() + "-->" + news.getContent());
} em.getTransaction().commit();
}
finally {
em.close();
}
}
}

News.java(参见12.2)

persistence.xml(参见12.2)

#2. 查询部分属性(Net Beans创建Java Project, 项目名称:SubProperty)

JpaQs.java

package lee;

import java.util.List;
import javax.persistence.*; import org.crazyit.model.*; public class JpaQs { private static final EntityManagerFactory emf = Persistence.createEntityManagerFactory("qs"); public static void main(String[] args) {
EntityManager em = emf.createEntityManager();
try { em.getTransaction().begin();
Query query = em.createQuery("select news.title , news.content"
+ " from News as news where news.id < ?1"
+ " and news.title like :title"); List result = query.setParameter(1, 8).setParameter("title", "%Java%").getResultList();
for (int i = 0; i < result.size(); i++) {
Object[] values = (Object[]) result.get(i);
System.out.println(values[0] + "-->" + values[1]);
} em.getTransaction().commit();
}
finally {
em.close();
}
}
}

News.java(参见12.2)

persistence.xml(参见12.2)

#3. 查询中使用构造器(Net Beans创建Java Project, 项目名称:Constructor)

NewsDTO.java

package org.crazyit.dto;

public class NewsDTO {

    private String title;
private String content; // constructor // setter
// getter
}

JpaQs.java

package lee;

import java.util.List;
import javax.persistence.*; import org.crazyit.model.*; public class JpaQs { private static final EntityManagerFactory emf = Persistence.createEntityManagerFactory("qs");
public static void main(String[] args) {
EntityManager em = emf.createEntityManager();
try {
em.getTransaction().begin();
Query query = em.createQuery("select distinct new org.crazyit.dto.NewsDTO(news.title"
+ " , news.content) from News as news where news.id < ?1"
+ " and news.title like :title"); List result = query.setParameter(1, 8).setParameter("title", "%Java%").getResultList();
for (int i = 0; i < result.size(); i++) {
System.out.println(result.get(i));
} em.getTransaction().commit();
}
finally {
em.close();
}
}
}

News.java(参见12.2)

persistence.xml(参见12.2)

3. JPQL的关联查询和多态查询

#1. 多态查询(Net Beans创建Java Project, 项目名称:PolyQuery)

News.java(参见12.2)

persistence.xml(参见12.2)

#2. 隐式连接(Net Beans创建Java Project, 项目名称:ImplicitJoin)

News.java(参见12.2)

persistence.xml(参见12.2)

#3. 显式连接(Net Beans创建Java Project, 项目名称:ExplicitJoin)

News.java(参见12.2)

persistence.xml(参见12.2)

4. 对查询结果集进行分页(Net Beans创建Java Project, 项目名称:Paging)

News.java(参见12.2)

persistence.xml(参见12.2)

5. 使用JPQL子查询和命名查询

#1. 子查询(Net Beans创建Java Project, 项目名称:SubQuery)

News.java(参见12.2)

persistence.xml(参见12.2)

#2. 命名查询(Net Beans创建Java Project, 项目名称:NamedQuery)

News.java(参见12.2)

persistence.xml(参见12.2)

6. JPQL的批量更新和删除

#1. 批量更新(Net Beans创建Java Project, 项目名称:Update)

News.java(参见12.2)

persistence.xml(参见12.2)

#2. 批量删除(Net Beans创建Java Project, 项目名称:Delete)

News.java(参见12.2)

persistence.xml(参见12.2)

JavaEE(17) - JPA查询API和JPQL的更多相关文章

  1. JavaEE(18) - JPA原生SQL查询和存储过程

    1. 使用原生SQL执行查询 2. 映射原生SQL查询的结果集 3. 使用原生SQL查询执行实体查询 4. 命名原生SQL查询 5. 在JPQL查询中调用存储过程

  2. JavaEE高级-JPA学习笔记

    *JPA概述 *JPA是什么? - Java Persistence API :用于对象持久化的API - Java EE 5.0平台标准的ORM规范,使得应用程序以统一的方式访问持久化层 - JPA ...

  3. Spring JPA 查询创建

    Spring JPA 查询创建 这是JPA内容的核心部分,可以收藏用作参阅文档. 1. 查询转化和关键字 例:一个JPA查询的转化 public interface UserRepository ex ...

  4. 快递查询API接口(trackingmore)

    快递查询接口 目前提供快递查询的接口平台有: Trackingmore 快递100 快递网 不同接口的区别: (1)Trackingmore支持380家快递公司,其中有55家为国内的快递,其余325家 ...

  5. 各种快递查询--Api接口

    授权成功我的密钥 爱查快递API使用说明文档 API地址: 以前:http://api.ickd.cn/?com=[]&nu=[]&id=[]&type=[]&enco ...

  6. JPA查询单个字段和多个字段返回类型总结

    原文地址:https://blog.csdn.net/weixin_40326509/article/details/80865646 在使用springboot中,需要使用JPQL和SQL去查询记录 ...

  7. spring data jpa查询部分字段、多余附加字段

    spring data jpa查询部分字段 第一种方法:使用 model 查询时转化 首先建立一个 model ,写上自己想要查询的字段,然后写上构造函数,这步很重要,因为spring jpa 转化时 ...

  8. 记一次JPA查询分页导致的数据丢失问题

    使用JPA查询,共17条数据,每页10条数据. 第一页与第二页有一条重复的数据,导致丢失一条数据 后查明原因发现,该查询使用了排序,排序字段的值在多条数据中相同,比如在3-11条是相同的值.此时跳到第 ...

  9. Hibernate 查询方式、JPA查询方式

    hibernate 查询方式: OID 查询 对象导航查询 HQL 方式查询 QBC方式查询 原生SQL方式查询 JPA 查询方式: OID 查询 对象导航查询 JPQL 方式查询 CriteriaB ...

随机推荐

  1. 手把手教popupWindow从下往上,以达到流行效果

    效果如图所看到的,点击開始button,popWindow从下往上出来,再点击popWindow外面,popWindow又从上往下消失 能够看出来,上面的popupWindow是半透明的,后面我会细说 ...

  2. android 编译调用C代码

    博客地址:www.zalezone.cn 前言 需求来源 这几天帮别人做一个简单的androidclient,也没什么功能,主要就是调用C代码来对手机的Wifi网络进行设置.于是也就引出了技术难点所在 ...

  3. SQLSERVER2014的内存优化表

    SQL Server 2014中的内存引擎(代号为Hekaton)将OLTP提升到了新的高度. 现在,存储引擎已整合进当前的数据库管理系统,而使用先进内存技术来支持大规模OLTP工作负载. 就算如此, ...

  4. hdu 2899 hdu 3400 三分/几何

    hdu2899 : 水提,直接三分,事实上求导后二分也能够. #include<iostream> #include<cstdio> using namespace std; ...

  5. 希尔排序----java实现

    思路:希尔排序是分组基础上的直接插入排序,给定的一个步长数组,每个小组先直接插入排序.虽然有四次循环,但是每次循环次数少. package com.sheepmu.text; import java. ...

  6. HDU 2845 Beans (动态调节)

    Beans Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  7. Search Bars(一个)

    A search bar provides an interface for text-based searches with a text box and buttons such as searc ...

  8. NYOJ 745 蚂蚁问题(两)

    蚂蚁的难题(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描写叙述 下雨了,下雨了.蚂蚁搬家了. 已知有n种食材须要搬走,这些食材从1到n依次排成了一个圈.小蚂蚁对每种 ...

  9. Performance Monitor采集性能数据

    Performance Monitor采集性能数据 Windows本身为我们提供了很多好用的性能分析工具,大家日常都使用过资源管理器,在里面能即时直观的看到CPU占用率.物理内存使用量等信息.此外新系 ...

  10. Chrome 控制台不完全指南(转)

    Chrome的开发者工具已经强大到没朋友的地步了,特别是其功能丰富界面友好的console,使用得当可以有如下功效: 更高「逼格」更快「开发调试」更强「进阶级的Frontender」 Bug无处遁形「 ...