- 浏览: 13970 次
- 性别:
- 来自: 北京
最近访客 更多访客>>
最新评论
-
墓里活人:
1.(分析依据):一次拿50跟走一米放下48跟回到原点(共吃2 ...
几个非常有意思的面试题 -
jasongreen:
yangyangsss 写道1 16 题意 ...
几个非常有意思的面试题 -
jieyuan_cg:
ldxfsh 写道jieyuan_cg 写道ldxfsh 写道 ...
几个非常有意思的面试题 -
ldxfsh:
jieyuan_cg 写道ldxfsh 写道
2.4个数:8. ...
几个非常有意思的面试题 -
hifun:
第一题是 1 3 9 27 吧?
几个非常有意思的面试题
hibernate查询语言hql
在hql中关键字不区分大小写,但是属性和类名区分大小写
1、简单属性查询【重要】
* 单一属性查询,返回结果集属性列表,元素类型和实体类中相应的属性类型一致
* 多个属性查询,返回的集合元素是对象数组,数组元素的类型和对应的属性在实体类中的类型一致
数组的长度取决与select中属性的个数
* 如果认为返回数组不够对象化,可以采用hql动态实例化Student对象
参见:QueryTest.java
2、实体对象查询【重要】
* N + 1问题,在默认情况下,使用query.iterate查询,有可以能出现N+1问题
所谓的N+1是在查询的时候发出了N+1条sql语句
1: 首先发出一条查询对象id列表的sql
N: 根据id列表到缓存中查询,如果缓存中不存在与之匹配的数据,那么会根据id发出相应的sql语句
* list和iterate的区别?
* list每次都会发出sql语句,list会向缓存中放入数据,而不利用缓存中的数据
* iterate:在默认情况下iterate利用缓存数据,但如果缓存中不存在数据有可以能出现N+1问题
参见:QueryTest.java
3、条件查询【重要】
* 可以采用拼字符串的方式传递参数
* 可以采用 ?来传递参数(索引从0开始)
* 可以采用 :参数名 来传递参数
* 如果传递多个参数,可以采用setParamterList方法
* 在hql中可以使用数据库的函数,如:date_format
参见:QueryTest.java
4、hibernate也支持直接使用sql进行查询
参见:QueryTest.java
5、外置命名查询
* 在映射文件中采用<query>标签来定义hql
* 在程序中采用session.getNamedQuery()方法得到hql查询串
参见:Student.hbm.xml、QueryTest.java
6、查询过滤器
* 在映射文件中定义过滤器参数
* 在类的映射中使用这些参数
* 在程序中启用过滤器
参见:Student.hbm.xml、QueryTest.java
7、分页查询【重要】
* setFirstResult(),从0开始
* setMaxResults,每页显示多少条数据
参见:QueryTest.java
8、对象导航查询,在hql中采用 . 进行导航【重要】
参见:QueryTest.java
9、连接查询【重要】
* 内连
* 外连接(左连接/右连接)
参见:QueryTest.java
10、统计查询【重要】
参见:QueryTest.java
11、DML风格的操作(尽量少用,因为和缓存不同步)
参见:QueryTest.java
package com.wuyu.hibernate;
import java.text.SimpleDateFormat;
import java.util.Iterator;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import junit.framework.TestCase;
public class QueryTest extends TestCase {
/**
* 单一属性查询
*/
public void test1() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回结果集属性列表,元素类型和实体类中相应的属性类型一致
List list = session.createQuery("select name from Student").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
String name = (String) it.next();
System.out.println(name);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 多个属性查询
*/
public void test2() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 查询多个属性,其集合元素事对象数组,数组元素的类型与实体类中相应的属性类型一致
List list = session.createQuery("select id,name from Student")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 返回实体对象
*/
public void test3() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 如果认为返回对象数组不够对象化,可以采用HQL动态实例化STUDENT对象
List list = session.createQuery(
"select new Student(id,name) from Student").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用别名进行查询
*/
public void test4() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session.createQuery(
"select new Student(s.id,s.name) from Student s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用AS别名查询
*/
public void test5() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session.createQuery(
"select new Student(s.id,s.name) from Student as s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/** *****************************注:TEST1,2,3,4,5都属于简单属性查询******************************** */
/**
* 实体对象查询
*/
public void test6() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合 ,可以忽略SELECT
List list = session.createQuery("from Student").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 实体对象查询,可以使用别名
*/
public void test7() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合 ,可以忽略SELECT
List list = session.createQuery("from Student s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 实体对象查询 使用AS别名
*/
public void test8() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合 ,可以忽略SELECT
List list = session.createQuery("from Student as s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 实体对象查询 使用SELECT 必须使用别名
*/
public void test9() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合
List list = session.createQuery("select s from Student as s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 不支持这种查询方式
*/
public void test10() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合
List list = session.createQuery("select * from Student as s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用iterate查询实体对象
*/
public void test11() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合,出现N+1问题.
Iterator it = session.createQuery("select s from Student as s")
.iterate();
while (it.hasNext()) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用iterate,list查询实体对象 * N + 1问题,在默认情况下,使用query.iterate查询,有可以能出现N+1问题
* 所谓的N+1是在查询的时候发出了N+1条sql语句 1: 首先发出一条查询对象id列表的sql N:
* 根据id列表到缓存中查询,如果缓存中不存在与之匹配的数据,那么会根据id发出相应的sql语句 list和iterate的区别?
* list每次都会发出sql语句,list会向缓存中放入数据,而不利用缓存中的数据
* iterate:在默认情况下iterate利用缓存数据,但如果缓存中不存在数据有可以能出现N+1问题
*/
public void test12() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 使用LIST借口
List list = session.createQuery("select s from Student as s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
System.out.println("---------------------------------------");
// 使用iterate借口查询
Iterator it = session.createQuery("select s from Student as s")
.iterate();
while (it.hasNext()) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/** **************************注:test6-12属于实体对象查询*************************************** */
/**
* 条件查询, 拼字符串的方法
*/
public void test13() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
Iterator it = session.createQuery(
"select s.name from Student as s where s.name like '%1%'")
.list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 条件查询:采用占位符的方式
*/
public void test14() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like ?");
Iterator it = query.setParameter(0, "%1%").list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 条件查询:采用参数名的方式查询
*/
public void test15() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like :myname");
Iterator it = query.setParameter("myname", "%1%").list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 多个条件查询:采用参数名的方式查询
*/
public void test16() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like :myname and s.id= :myid");
Iterator it = query.setParameter("myname", "%1%").setParameter(
"myid", 12).list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用IN的条件查询
*/
public void test17() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like :myname and s.id in(:myid)");
Iterator it = query.setParameter("myname", "%1%").setParameterList(
"myid", new Object[] { 1, 2, 3, 4, 5, 12 }).list()
.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 查询2008-02的数据
*/
public void test18() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 可以使用数据库的函数
Query query = session
.createQuery("select s.createTime from Student as s where date_format(s.createTime,'%Y-%m') = ?");
Iterator it = query.setParameter(0, "2008-02").list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 查询时间段中的数据
*/
public void test19() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// 可以使用数据库的函数
Query query = session
.createQuery("select s.createTime from Student as s where s.createTime between ? and ?");
Iterator it = query.setParameter(0,
sdf.parse("2008-01-10 00:00:00")).setParameter(1,
sdf.parse("2008-01-30 23:59:59")).list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/** ********************test13-19条件查询********************************************* */
/**
* 原生SQL查询
*/
public void test20() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回结果集属性列表,元素类型和实体类中相应的属性类型一致
List list = session.createSQLQuery("select name from t_student")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
String name = (String) it.next();
System.out.println(name);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
*
* 外置命名查询 在映射文件中采用<query>标签来定义hql 在程序中采用session.getNamedQuery()方法得到hql查询串
*/
public void test21() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
List list = session.getNamedQuery("searchStudents").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 过滤查询
*
* 在映射文件中定义过滤器参数 在类的映射中使用这些参数 在程序中启用过滤器
*/
public void test22() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 启用过滤器,设置参数
session.enableFilter("studentFilter").setParameter("myid", 10);
List list = session.getNamedQuery("searchStudents").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
System.out.println(st.getId());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 分页查询
*/
public void test23() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// setFirstResult(),从0开始
// setMaxResults,每页显示多少条数据
List list = session.createQuery("from Student").setFirstResult(3)
.setMaxResults(2).list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 对象导航查询
*/
public void test24() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session
.createQuery(
"select s.name from Student s where s.classes.name like '%1%'")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
String name = (String) it.next();
System.out.println(name);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 统计查询
*/
public void test25() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// List list = session.createQuery("select count(*) from Student")
// .list();
// for (Iterator it = list.listIterator(); it.hasNext();) {
// Long count = (Long) it.next();
// System.out.println(count);
// }
// 返回为单一值时
Long count = (Long) session.createQuery(
"select count(*) from Student").uniqueResult();
System.out.println(count);
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 内连接查询
*/
public void test26() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session
.createQuery(
"select c.name,s.name from Student s inner join s.classes c")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 左外连接查询
*/
public void test27() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 查询所有的STUDENTS以及匹配的classes
List list = session
.createQuery(
"select c.name,s.name from Classes c left join c.students s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
*
*/
public void test28() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 查询所有的CLASSES以及匹配的STUDENTS
List list = session
.createQuery(
"select c.name,s.name from Classes c right join c.students s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
}
在hql中关键字不区分大小写,但是属性和类名区分大小写
1、简单属性查询【重要】
* 单一属性查询,返回结果集属性列表,元素类型和实体类中相应的属性类型一致
* 多个属性查询,返回的集合元素是对象数组,数组元素的类型和对应的属性在实体类中的类型一致
数组的长度取决与select中属性的个数
* 如果认为返回数组不够对象化,可以采用hql动态实例化Student对象
参见:QueryTest.java
2、实体对象查询【重要】
* N + 1问题,在默认情况下,使用query.iterate查询,有可以能出现N+1问题
所谓的N+1是在查询的时候发出了N+1条sql语句
1: 首先发出一条查询对象id列表的sql
N: 根据id列表到缓存中查询,如果缓存中不存在与之匹配的数据,那么会根据id发出相应的sql语句
* list和iterate的区别?
* list每次都会发出sql语句,list会向缓存中放入数据,而不利用缓存中的数据
* iterate:在默认情况下iterate利用缓存数据,但如果缓存中不存在数据有可以能出现N+1问题
参见:QueryTest.java
3、条件查询【重要】
* 可以采用拼字符串的方式传递参数
* 可以采用 ?来传递参数(索引从0开始)
* 可以采用 :参数名 来传递参数
* 如果传递多个参数,可以采用setParamterList方法
* 在hql中可以使用数据库的函数,如:date_format
参见:QueryTest.java
4、hibernate也支持直接使用sql进行查询
参见:QueryTest.java
5、外置命名查询
* 在映射文件中采用<query>标签来定义hql
* 在程序中采用session.getNamedQuery()方法得到hql查询串
参见:Student.hbm.xml、QueryTest.java
6、查询过滤器
* 在映射文件中定义过滤器参数
* 在类的映射中使用这些参数
* 在程序中启用过滤器
参见:Student.hbm.xml、QueryTest.java
7、分页查询【重要】
* setFirstResult(),从0开始
* setMaxResults,每页显示多少条数据
参见:QueryTest.java
8、对象导航查询,在hql中采用 . 进行导航【重要】
参见:QueryTest.java
9、连接查询【重要】
* 内连
* 外连接(左连接/右连接)
参见:QueryTest.java
10、统计查询【重要】
参见:QueryTest.java
11、DML风格的操作(尽量少用,因为和缓存不同步)
参见:QueryTest.java
package com.wuyu.hibernate;
import java.text.SimpleDateFormat;
import java.util.Iterator;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import junit.framework.TestCase;
public class QueryTest extends TestCase {
/**
* 单一属性查询
*/
public void test1() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回结果集属性列表,元素类型和实体类中相应的属性类型一致
List list = session.createQuery("select name from Student").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
String name = (String) it.next();
System.out.println(name);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 多个属性查询
*/
public void test2() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 查询多个属性,其集合元素事对象数组,数组元素的类型与实体类中相应的属性类型一致
List list = session.createQuery("select id,name from Student")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 返回实体对象
*/
public void test3() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 如果认为返回对象数组不够对象化,可以采用HQL动态实例化STUDENT对象
List list = session.createQuery(
"select new Student(id,name) from Student").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用别名进行查询
*/
public void test4() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session.createQuery(
"select new Student(s.id,s.name) from Student s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用AS别名查询
*/
public void test5() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session.createQuery(
"select new Student(s.id,s.name) from Student as s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/** *****************************注:TEST1,2,3,4,5都属于简单属性查询******************************** */
/**
* 实体对象查询
*/
public void test6() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合 ,可以忽略SELECT
List list = session.createQuery("from Student").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 实体对象查询,可以使用别名
*/
public void test7() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合 ,可以忽略SELECT
List list = session.createQuery("from Student s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 实体对象查询 使用AS别名
*/
public void test8() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合 ,可以忽略SELECT
List list = session.createQuery("from Student as s").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 实体对象查询 使用SELECT 必须使用别名
*/
public void test9() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合
List list = session.createQuery("select s from Student as s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 不支持这种查询方式
*/
public void test10() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合
List list = session.createQuery("select * from Student as s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用iterate查询实体对象
*/
public void test11() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回STUDENT 对象的集合,出现N+1问题.
Iterator it = session.createQuery("select s from Student as s")
.iterate();
while (it.hasNext()) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用iterate,list查询实体对象 * N + 1问题,在默认情况下,使用query.iterate查询,有可以能出现N+1问题
* 所谓的N+1是在查询的时候发出了N+1条sql语句 1: 首先发出一条查询对象id列表的sql N:
* 根据id列表到缓存中查询,如果缓存中不存在与之匹配的数据,那么会根据id发出相应的sql语句 list和iterate的区别?
* list每次都会发出sql语句,list会向缓存中放入数据,而不利用缓存中的数据
* iterate:在默认情况下iterate利用缓存数据,但如果缓存中不存在数据有可以能出现N+1问题
*/
public void test12() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 使用LIST借口
List list = session.createQuery("select s from Student as s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
System.out.println("---------------------------------------");
// 使用iterate借口查询
Iterator it = session.createQuery("select s from Student as s")
.iterate();
while (it.hasNext()) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/** **************************注:test6-12属于实体对象查询*************************************** */
/**
* 条件查询, 拼字符串的方法
*/
public void test13() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
Iterator it = session.createQuery(
"select s.name from Student as s where s.name like '%1%'")
.list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 条件查询:采用占位符的方式
*/
public void test14() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like ?");
Iterator it = query.setParameter(0, "%1%").list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 条件查询:采用参数名的方式查询
*/
public void test15() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like :myname");
Iterator it = query.setParameter("myname", "%1%").list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 多个条件查询:采用参数名的方式查询
*/
public void test16() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like :myname and s.id= :myid");
Iterator it = query.setParameter("myname", "%1%").setParameter(
"myid", 12).list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 使用IN的条件查询
*/
public void test17() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
Query query = session
.createQuery("select s.name from Student as s where s.name like :myname and s.id in(:myid)");
Iterator it = query.setParameter("myname", "%1%").setParameterList(
"myid", new Object[] { 1, 2, 3, 4, 5, 12 }).list()
.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 查询2008-02的数据
*/
public void test18() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 可以使用数据库的函数
Query query = session
.createQuery("select s.createTime from Student as s where date_format(s.createTime,'%Y-%m') = ?");
Iterator it = query.setParameter(0, "2008-02").list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 查询时间段中的数据
*/
public void test19() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// 可以使用数据库的函数
Query query = session
.createQuery("select s.createTime from Student as s where s.createTime between ? and ?");
Iterator it = query.setParameter(0,
sdf.parse("2008-01-10 00:00:00")).setParameter(1,
sdf.parse("2008-01-30 23:59:59")).list().iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/** ********************test13-19条件查询********************************************* */
/**
* 原生SQL查询
*/
public void test20() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 返回结果集属性列表,元素类型和实体类中相应的属性类型一致
List list = session.createSQLQuery("select name from t_student")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
String name = (String) it.next();
System.out.println(name);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
*
* 外置命名查询 在映射文件中采用<query>标签来定义hql 在程序中采用session.getNamedQuery()方法得到hql查询串
*/
public void test21() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
List list = session.getNamedQuery("searchStudents").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 过滤查询
*
* 在映射文件中定义过滤器参数 在类的映射中使用这些参数 在程序中启用过滤器
*/
public void test22() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 启用过滤器,设置参数
session.enableFilter("studentFilter").setParameter("myid", 10);
List list = session.getNamedQuery("searchStudents").list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getName());
System.out.println(st.getId());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 分页查询
*/
public void test23() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// setFirstResult(),从0开始
// setMaxResults,每页显示多少条数据
List list = session.createQuery("from Student").setFirstResult(3)
.setMaxResults(2).list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Student st = (Student) it.next();
System.out.println(st.getId());
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 对象导航查询
*/
public void test24() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session
.createQuery(
"select s.name from Student s where s.classes.name like '%1%'")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
String name = (String) it.next();
System.out.println(name);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 统计查询
*/
public void test25() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// List list = session.createQuery("select count(*) from Student")
// .list();
// for (Iterator it = list.listIterator(); it.hasNext();) {
// Long count = (Long) it.next();
// System.out.println(count);
// }
// 返回为单一值时
Long count = (Long) session.createQuery(
"select count(*) from Student").uniqueResult();
System.out.println(count);
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 内连接查询
*/
public void test26() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
//
List list = session
.createQuery(
"select c.name,s.name from Student s inner join s.classes c")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
* 左外连接查询
*/
public void test27() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 查询所有的STUDENTS以及匹配的classes
List list = session
.createQuery(
"select c.name,s.name from Classes c left join c.students s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
/**
*
*/
public void test28() {
Session session = null;
try {
session = HibernateUtils.getSession();
// 开启事物
session.beginTransaction();
// 查询所有的CLASSES以及匹配的STUDENTS
List list = session
.createQuery(
"select c.name,s.name from Classes c right join c.students s")
.list();
for (Iterator it = list.listIterator(); it.hasNext();) {
Object[] obj = (Object[]) it.next();
System.out.println("name=====" + obj[1]);
System.out.println("id=========" + obj[0]);
}
// 提交事物
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
// 回滚事物
session.getTransaction().rollback();
} finally {
// 关闭SESSION
HibernateUtils.closeSession(session);
}
}
}
相关推荐
### Struts+Hibernate查询所有记录 #### 一、概述 在Java Web开发中,Struts与Hibernate是非常流行的框架组合,用于构建复杂的企业级应用。本文将详细介绍如何利用Struts和Hibernate来实现对Oracle数据库中所有...
【hibernate查询详解】 Hibernate,作为一款强大的Java对象关系映射(ORM)框架,极大地简化了数据库操作。它允许开发者使用面向对象的方式来处理数据库,从而避免了传统的JDBC编码方式带来的复杂性。本篇文章将...
利用MYSQL数据库提供的样例数据库world建立的查询小例子。已经建立好了数据库对应的...本项目主要是为了练习使用Hibernate查询数据库。如果有什么问题可以发站内信或者邮件asddf14@hotmail.com。我会尽量解答一下~~~
Hibernate 查询语言 HQL Hibernate 查询语言 HQL 是一种面向对象的查询语言,用于检索对象。它提供了灵活多样的查询机制,包括导航对象图、通过标识符检索、使用 HQL 检索对象、使用 Hibernate 条件 API 和使用本地...
本实践项目“Hibernate查询映射试验”旨在通过一系列示例帮助开发者掌握Hibernate中的查询映射技术,包括HQL(Hibernate Query Language)和Criteria API。 首先,Hibernate的核心是对象关系映射(ORM),它允许...
在深入探讨Hibernate查询缓存之前,我们先了解一下Hibernate的基础概念。Hibernate是一个强大的Java持久化框架,它简化了数据库操作,提供了对象关系映射(ORM)功能。在Hibernate中,对象的状态分为瞬时态、持久态...
最后,`hibernate查询`这个压缩包可能包含了一些示例代码和配置文件,用于演示如何在Java项目中实现上述查询方式。通过分析这些文件,你可以更好地理解Hibernate查询的工作原理,并将其应用到自己的项目中。 总之,...
【标题】:“Hibernate查询缓存及实现.PPT” 【描述】:“Hibernate查询缓存及实现.PPT” 在本文中,我们将深入探讨Hibernate框架中的查询缓存机制及其实施步骤,这是一项旨在提高应用程序性能的重要功能。查询...
Hibernate查询语言HQL
【标题】:“Hibernate查询语句写在配置文件中” 【正文】: Hibernate 是一个流行的 Java 应用程序框架,主要用于简化数据库操作。它提供了一种对象关系映射(ORM)机制,将数据库操作转化为对 Java 对象的操作,...
在“hibernate查询、连接池、二级缓存”这个主题中,我们将深入探讨这三个关键概念。 首先,让我们来了解**Hibernate查询**。Hibernate 提供了丰富的查询方式,包括HQL(Hibernate Query Language)和Criteria API...
HQL Hibernate查询语言,HQL的学习和参考的文档,开发必备。
Hibernate提供了一种灵活的查询语言——HQL(Hibernate Query Language),以及 Criteria 查询和 Criteria API,它们都可以用来获取数据表中的特定字段。 二、Hibernate配置 在使用Hibernate进行查询前,首先需要...
hibernate查询-hql等教程,对于学习hibernate有很好的帮助。
Hibernate支持两种类型的查询:原生SQL查询和Hibernate查询语言(HQL)。原生SQL查询允许开发者直接执行SQL语句,而HQL则是面向对象的查询语言,类似于SQL但更接近于Java。 4. 封装SQL查询结果为对象: - `...
Hibernate查询首先介绍get()和load()方法的区别:get()方法和load()方法的区别主要在于对二级缓存的使用上。load()方法会使用二级缓存,而get()方法在一级缓存没有找到会直接查询数据库,不会去二级缓存中查找。 get...
"Huikegeneratecodetool"这个文件可能是一个代码生成工具,它能自动生成符合Hibernate查询规则的代码,从而提高开发效率,减少手动编写SQL的错误。 总的来说,理解Hibernate查询中单一字段与多字段的区别对于优化...