EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(1)
来源:互联网 发布:表白用的编程 编辑:程序博客网 时间:2024/06/06 11:39
JPQL就是一种查询语言,具有与SQL相类似的特征,JPQL是完全面向对象的,具备继承、多态和关联等特性,和hibernateHQL很相似。
查询语句的参数
JPQL语句支持两种方式的参数定义方式:命名参数和位置参数。。在同一个查询语句中只允许使用一种参数定义方式。
命令参数的格式为:“: +参数名”
例:
Query query = em.createQuery("select p from Person p wherep.personid=:Id");
query.setParameter("Id",newInteger(1));
位置参数的格式为“?+位置编号”
例:
Query query = em.createQuery("select p from Person p wherep.personid=?1");
query.setParameter(1,newInteger(1));
如果你需要传递java.util.Date或java.util.Calendar参数进一个参数查询,你需要使用一个特殊的setParameter()方法,相关的setParameter方法定义如下:
publicinterface Query
{
//命名参数查询时使用,参数类型为java.util.Date
Query setParameter(String name,java.util.Date value, TemporalType temporalType);
//命名参数查询时使用,参数类型为java.util.Calendar
Query setParameter(String name,Calendar value, TemporalType temporalType);
//位置参数查询时使用,参数类型为java.util.Date
Query setParameter(int position,Date value, TemporalType temporalType);
//位置参数查询时使用,参数类型为java.util.Calendar
Query setParameter(int position,Calendar value, TemporalType temporalType);
}
因为一个Date或Calendar对象能够描述一个真实的日期、时间或时间戳.所以我们需要告诉Query对象怎么使用这些参数,我们把javax.persistence.TemporalType作为参数传递进setParameter方法,告诉查询接口在转换java.util.Date或java.util.Calendar参数到本地SQL时使用什么数据库类型。
下面通过实例来学习JPQL语句,例子的entity Bean有Person, Order, OrderItem,他们之间的关系是:一个Person有多个Order,一个Order有多个OrderItem。
JPQL语句的大小写敏感性:除了Java类和属性名称外,查询都是大小写不敏感的。所以,SeLeCT和sELEct以及SELECT相同的,但是com.foshanshop.ejb3.bean.Person和com.foshanshop.ejb3.bean.PERSon是不同的,person.name和person.NAME也是不同的。
命名查询
可以在实体bean上通过@NamedQueryor @NamedQueries预先定义一个或多个查询语句,减少每次因书写错误而引起的BUG。通常把经常使用的查询语句定义成命名查询。
定义单个命名查询:
@NamedQuery(name="getPerson",query="FROM Person WHEREpersonid=?1")
@Entity
publicclass Person implementsSerializable{
如果要定义多个命名查询,应在@javax.persistence.NamedQueries里定义@NamedQuery:
@NamedQueries({
@NamedQuery(name="getPerson",query="FROM Person WHEREpersonid=?1"),
@NamedQuery(name="getPersonList",query="FROM Person WHEREage>?1")
})
@Entity
publicclass Person implementsSerializable{
当命名查询定义好了之后,我们就可以通过名称执行其查询。代码如下:
Query query= em.createNamedQuery("getPerson");
query.setParameter(1,1);
排序(order by)
"ASC"和"DESC"分别为升序和降序,JPQL中默认为asc升序
例:
//先按年龄降序排序,然后按出生日期升序排序
Query query =em.createQuery("select p from Person porder by p.age desc, p.birthdayasc");
查询部分属性
通常来说,都是针对Entity类的查询,返回的也是被查询的Entity类的实体。JPQL也允许我们直接查询返回我们需要的属性,而不是返回整个Entity。在一些Entity中属性特别多的情况,这样的查询可以提高性能
例:
//只查询我们感兴趣的属性(列)
Queryquery=em.createQuery("select p.personid, p.name from Person p orderby p.personid desc ");
//集合中的元素不再是Person,而是一个Object[]对象数组
List result =query.getResultList();
if(result!=null){
Iterator iterator =result.iterator();
while( iterator.hasNext()){
Object[] row = ( Object[])iterator.next();
int personid =Integer.parseInt(row[0].toString());
String PersonName =row[1].toString();
。。。。
}
}
查询中使用构造器(Constructor)
JPQL支持将查询的属性结果直接作为一个javaclass的构造器参数,并产生实体作为结果返回。例如上面的例子只获取personentity bean的name andpersonid属性,我们不希望返回的集合的元素是object[],而希望用一个类来包装它。就要用到使用构造器。
例:
publicclass SimplePerson {
privateStringname;
publicSimplePerson(){
}
publicSimplePerson(Integerpersonid, String name) {
this.name= name;
this. personid =personid;
}
}
查询代码为:
//我们把需要的两个属性作为SimplePerson的构造器参数,并使用new函数。
Query query =em.createQuery("select newcom.foshanshop.ejb3.bean.SimplePerson(p. personid, p.name) fromPerson p order by p.personid desc");
//集合中的元素是SimplePerson对象
List result =query.getResultList();
if(result!=null){
Iterator iterator =result.iterator();
while( iterator.hasNext()){
SimplePerson simpleperson =(SimplePerson) iterator.next();
。。。。
}
}
聚合查询(Aggregation)
JPQL支持的聚合函数包括:
1. AVG()
2. SUM()
3. COUNT(),返回类型为Long,注意count(*)语法在hibernate中可用,但在toplink其它产品中并不可用
4. MAX()
5. MIN()
例:
//获取最大年龄
Query query =em.createQuery("selectmax(p.age) from Person p");
Object result= query.getSingleResult();
String maxAge= result.toString();
//获取平均年龄
query =em.createQuery("selectavg(p.age) from Person p");
//获取最小年龄
query =em.createQuery("selectmin(p.age) from Person p");
//获取总人数
query =em.createQuery("selectcount(p) from Person p");
//获取年龄总和
query =em.createQuery("selectsum(p.age) from Person p");
如果聚合函数不是select...from的唯一一个返回列,需要使用"GROUP BY"语句。"GROUPBY"应该包含select语句中除了聚合函数外的所有属性。
例:
//返回男女生各自的总人数
Query query =em.createQuery("select p.sex, count(p) from Personp group by p.sex");
//集合中的元素不再是Person,而是一个Object[]对象数组
List result= query.getResultList();
如果还需要加上查询条件,需要使用"HAVING"条件语句而不是"WHERE"语句
例:
//返回人数超过1人的性别
Query query =em.createQuery("select p.sex, count(p) from Person p group by p.sexhaving count(*)>?1");
//设置查询中的参数
query.setParameter(1, newLong(1));
//集合中的元素不再是Person,而是一个Object[]对象数组
List result =query.getResultList();
0 0
- EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(1)
- EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(1)
- EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(2)
- EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(2)
- EJB3.0查询语句JPQL用法
- EJB3.0查询语句JPQL用法
- EJB3.0 JPQL 查询
- JPA学习记录五(使用JPA加载_更新_删除对象及使用JPQL语句进行查询)
- JPA JPQL 查询、排序.....
- JPA查询语言 JPQL
- JPA JPQL 查询、排序
- JPA JPQL 查询、排序
- JPA JPQL 查询、排序
- JPA JPQL 查询、排序.....
- 【JPA】JPQL查询 -- 小结
- jpa之jpql查询
- 使用 JPQL 和原生 SQL 查询 JPA 实体(转)
- jpql 语句的查询
- Android开发:获取屏幕宽和高的两种方法(px、dip、分辨率之间的关系及px与dip互相转化)
- js立即执行函数
- Office 2016正式发布啦
- android studio 启动手机报错time out 解决方案
- 【lumen】基础点记录使用
- EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(1)
- Redis介绍以及安装(Linux)
- iOS——iOS9适配和xcode7适配
- Android 动画原理
- EJB3 JPA JPQL 语句 查询 使用 函数 分页 子查询(2)
- NetBeans链接MySQL的事例,
- nyoj 915 +-字符串
- iPhone 从程序跳转到AppStore评论页面
- Linux内核源代码情景分析---第五章 文件系统