[转] JPQL
原文地址:http://blog.csdn.net/suncaishen/article/details/6512028
select name ,age from user; //原生SQL语句
select u.name,u.age from User u; //JPQL语句
select u from User u; //JPQL语句
SQL语句是在数据库空间中对字段,列,行进行操作
JPQL语句是在EJB实体空间中面向对象,属性进行操作
JPQL必须由JPA的JPQL解析器解析为SQL才能执行,必须先获取Query对象
参数查询
1命名参数查询
entityManager.createQuery("select u from User u where u.age=:param");
query.setParameter("param",24);
List<User> result=(List<User>)query.getResultList();
2位置参数查询
"select u from User u where u.age=?1"
query.setParameter(1,24);
3实体参数(JPQL中除了基本类型外,还可以是对象类型)
"select u from User u where u.person=?1"
Person p=new Person();
p.setId(1);
query.setParameter(1,p);
JPQL运算符
算术运算符 + - * /
关系运算符 = > < >= <= <>
逻辑运算符 between ,like , in , is null,is empty,member of,not ,and ,or
1 not
"select u from User u where not(u.cityid=?1)"
2 between和sql中一样
3 in 在给定的值列表中查询
"select u from User u where u.cityid in(1,2,3)"
4 like ( _ 表示一个字符,%表示任意数量字符 )
xxxx where u.name like ' 张% '
5 is null (实体的属性是否为空,即实体属性映射的字段是否为空)
"select u from User u where u.cityid is null"
6 is empty (与is null 不同的是,它针对实体的集合属性 内有没有元素。
虽然集合对象是存在的,但是集合内没有元素)
select o from Order o where o.orderItems is empty
条件查询
1排序查询 asc升序 desc降序
order by p.age desc,p.birthday asc
2聚合函数查询
avg() 平均值,返回Double count()返回Long max() min() sum()
以上除了count外其它的函数的参数对应的是 单个的字段,即属性而不是对象
HAVING和WHERE的区别。一个是先分组,再对组进行筛选;一个是先筛选,然后对筛选后的记录进行分组。
构造器查询
"select new com.jsun.Person(p.name) from Person p"
Person有这个构造器时,即Person(String name),成功返回对象。
关联查询(实际工作中仍然会有这种需求)
left join 允许右边实体表达式的实体为空,这里的实体指 集合属性
inner join 右边必须存在
"select o from Order o inner join o.orderItems"
在默认查询中,集合属性是懒加载的。只有用的时候JPA才会再发SQL语句
在查询的时候我们希望一次全抓取出来怎么办?用 fetch
(其实left join和inner join在这里使用主要是为了配合fetch,一次抓取,因为默认的是懒加载)
"select o from Order o inner join fetch o.orderItems"
排除相同记录DISTINCT
select distinct o from Order o
(还可以配合聚合函数使用)
如 select count(distinct o) from Order o
JPQL内置函数
字符串函数
concat(str1,str2)
substring(string,position,length)
trim( [leading | trailing | both] sub_str from str)
upper(str)
lower(str)
length(str)
locate(searchString,initPosition)
日期,时间函数
CURRENT_DATE //返回当前日期(这是数据库端的时间)
CURRENT_TIME //返回当前时间
CURRENT_TIMESTAMP //返回当前日期时间
数学函数
ABS(number) //绝对值
SQRT(number) //平方根
MOD(num,div)//取模
SIZE(collection) //返回集合中元素的数量
如:select o from Order o where size(o.items)>10
使用子查询
xxxx in(子查询)
xxxx not in(子查询)
exists(子查询)
not exists(子查询 ) exists存在的意思 即子查询的结果不为空就是存在
分页查询
用到了query接口的两个方法
setMaxResults(int) //设置获取多少条记录
和setFirstResult(int)//结果集开始的索引,索引默认从0开始
以上两个方法都返回Query对象所以可以组成方法链
query.setMaxResults(max).setFirstResult(index).getResultList()
批量操作(批量更新和批量删除)
建议将所有批量操作与不连续的事务隔离开,
批量操作可能造成受管实体与数据库的不一致
原生SQL查询与调用存储过程(EJB3.0不支持以OUT参数的形式返回的存储过程)
Query query=entityManager.createNativeQuery(" {call pro_1(?)} ");
query.setParameter(1,"jsun");
//无返回值存储过程
query.executeUpdate();
//返回单个值的存储过程
String result=(String)query.getSingleResult();
//返回全部列的存储过程
List<User> results=(List<User>)query.getResultList();
//返回部分列的存储过程
List<Object[]> results=(List<Object[]>)query.getResultList();
for(Object[] row:results){
row[0],row[1]
}
[转] JPQL的更多相关文章
- Atitit oodbms的查询,面向对象的sql查询jpa jpql hql
Atitit oodbms的查询,面向对象的sql查询jpa jpql hql 1.1. 标准API历史1 1.2. JPA定义了独特的JPQL(Java Persistence Query Lang ...
- JPA学习(6)JPQL
JPQL语言,即 Java Persistence Query Language 的简称.JPQL 是一种和 SQL 非常类似的中间性和对象化查询语言,它最终会被编译成针对不同底层数据库的 SQL 查 ...
- JPA学习---第八节:使用JPQL语句进行查询
1.JPQL 语句查询,代码如下: @Test public void query(){ EntityManagerFactory factory = Persistence.createEntity ...
- JavaEE(17) - JPA查询API和JPQL
1. 获取查询结果 2. JPQL函数和JPQL表达式 #1. 使用from子句 #2. 查询部分属性 #3. 查询中使用构造器 3. JPQL的关联查询和多态查询 #1. 多态查询 #2. 隐式连接 ...
- JPQL
JPQL语言 JPQL语言,即 Java Persistence Query Language 的简称. JPQL是一种和 SQL 非常类似的中间性和对象化查询语言, 它最终会被编译成针对不同底层数据 ...
- 如何使用JPQL写纯SQL语句
使用JPQL,需要把SQL语句修改成类似HQL 语句.SQL 查询的是数据库,而JPQL 查询的是对象和属性,在语法上是有些不同的.对于有些用JPQL 无法写出来的查询,还是使用原生SQL写出来方便 ...
- JPQL的关联查询
一般情况下,直接使用mysql语句写关联语句,是join on 的形式,如下: select * from tablea as a left join tableb as b on b.tablea_ ...
- JPQL设置自增长、只读、文本类型等的注解
JAVA中使用JPQL 一种设置id自动生成,自增长的方法 private long id; @Id @GeneratedValue(generator="_native") @G ...
- JPQL模糊匹配单个字符
JPQL模糊匹配,不是%,而是单个字符,该怎么办?比如我要查出数据库中满足后三位是数字的字符串 对于mysql来说,使用通配符 %和_可以轻松解决,但是对于JPQL来说模糊查询就伤脑筋了... 有一个 ...
随机推荐
- MMORPG大型游戏设计与开发(part4 of net)
上一节简单的介绍了服务器消息处理的流程,想必大家对这方面有了初步的认识,接下来我们需要知道和掌握的便是其中一些重要的方法,进一步深入熟悉整个构架. 1.FD_*系列宏函数 FD_ZERO(fd_set ...
- SQL Server 索引设计指南
https://msdn.microsoft.com/zh-cn/library/jj835095(v=sql.120).aspx#Nonclustered
- [No000018]都在背单词,为啥学霸那么厉害-如何在一天内记200个单词?
- 第三方登录 (faceBook )
1.iOS 第三方登录(Facebook,Twitter...)http://www.jianshu.com/p/f64d5ad2ef2a
- SPM paired t-test步骤
首先感谢大神空里流霜耐心的讲解,这篇笔记内容主要是整理他的谆谆教导,虽然他也看不到>< 所有数据都要经过平滑. Paired t-test虽然在2nd-level analysis中,但是 ...
- js 事件冒泡是什么如何用jquery阻止事件冒泡
什么是事件起泡:一个事件不能凭空产生,这就是事件的发生等等,接下来为大家介绍下jquery阻止事件起泡以及关于js事件起泡的验证,感兴趣的朋友可以参考下哈 (1)什么是事件起泡 首先你要明 ...
- js jquery 关闭弹出页面 并刷新父页面(window.opener)
function Closepage() { if (window.opener && !window.opener.closed) { window.parent.opener.lo ...
- MYSQL游标使用
CREATE PROCEDURE `sp_UpdateData`() BEGIN ); /*修改会员卡的几个金额*/ DECLARE done INT DEFAULT FALSE; DECLARE c ...
- [py]简易pick lucky num程序
程序功能: 1,用户输入数字,当用户输入指定数字时候,输出他输入的循环那次 2,第二次询问是否还要输 3,如果no 则 终止 4,如果yes则继续输入 判断输入是否大于首次输入的 如果大于则开始循环输 ...
- Android-完全退出当前应用程序的四种方法
Android程序有很多Activity,比如说主窗口A,调用了子窗口B,如果在B中直接finish(), 接下里显示的是A.在B中如何关闭整个Android应用程序呢?本人总结了几种比较简单的实现方 ...