Query对象

    方便的对数据库和持久化对象进行查询,两种表达方式:HQL和SQL;

    Query经常用来绑定查询参数,限制查询条数。并最终执行查询语句。

HQL

查询一个简单类(查询所有)

	@Test //修改方法
public void test3(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
Query query = session.createQuery("from User");
List list = query.list();
System.out.println(list);
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

 分页查询

		@Test //修改方法
public void test3(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
Query query = session.createQuery("from User");
query.setFirstResult(0);//设置开始的位置
query.setMaxResults(10);//设置查询多少条
List list = query.list();
for (Object object : list) {
System.out.println(object);
}
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

 查看指定列

          @Test //查询指定列
public void test4(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
//查询指定列时,必须在javabean中提供该字段的构造方法 其他列为空
Query query = session.createQuery("select new User(username,password) from User");
List<User> list = query.list();
for (User u : list) {
System.out.println(u);
}
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

条件查询

	@Test //条件查询(无名称参数)
public void test5(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
//查询指定列时,必须在javabean中提供默认的构造方法(无参构造)
//因为有参会替换无参 然而在条件查询时会调用无参构造
/*条件查询(无名称参数)
* Query query = session.createQuery("from User where username=?");
query.setParameter(0, "zhangsan111");*/
//条件查询(有名称参数)
Query query = session.createQuery("from User where username=:myusername");
query.setParameter("myusername", "zhangsan111");
User user = (User) query.uniqueResult();
System.out.println(user);
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

 命名查询

在customer.hbm.xml中class标签外定义一个<query>标签

 <query name="select1">
from Customer where id=?
</query>

  测试方法

        @Test	//测试命名查询
public void test03(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
Query qy = session.getNamedQuery("select1");
qy.setParameter(0, 1);//添加参数
Customer ct = (Customer) qy.uniqueResult();
System.out.println(ct.getId());
//操作
bt.commit();
session.close();
}

  

 SQL

  查询所有

          @Test //sql查询
public void test6(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
SQLQuery query = session.createSQLQuery("select * from user"); List<Object[]> list = query.list();
for (Object object : list) {
//打印地址值
System.out.println(object);
}
/*object对象指向User类
* query.addEntity(User.class);
List<User> list = query.list();
for (User user : list) {
System.out.println(user);
}*/
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

  条件查询

          @Test //sql条件查询()
public void test7(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
SQLQuery query = session.createSQLQuery("select * from user where username=?");
query.setParameter(0, "zhangsan111");
//object对象指向User类
query.addEntity(User.class);
User user = (User) query.uniqueResult();//转换时还是会让Query对象识别到User这个类
System.out.println(user);
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

Criteria对象

查询所有

          @Test //Criteria查询全部
public void test8(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
Criteria criteria = session.createCriteria(User.class);
List list = criteria.list();
for (Object object : list) {
System.out.println(object);
}
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

  单条件查询/多条件查询

          @Test //Criteria条件查询查询
public void test9(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
Criteria criteria = session.createCriteria(User.class);
               //条件1
criteria.add(Restrictions.eq("username", "zhangsan111"));
               //条件2
               criteria.add(Restrictions.eq("username","zhangsan111"));
List list = criteria.list();
for (Object object : list) {
System.out.println(object);
}
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

  条件或

@Test //Criteria条件查询查询or
public void test10(){
Session session = HibernateUtils.getSession(); // 相当于得到一个Connection。
// 操作
Criteria criteria = session.createCriteria(User.class);
//条件1
criteria.add(Restrictions.or(Restrictions.eq("username", "zhangsan111"),Restrictions.eq("username", "fanjiankang"))); List list = criteria.list();
for (Object object : list) {
System.out.println(object);
}
//不需要关闭Configuration 因为Configuration不是轻量级的。这样一个项目就只产生一个Configuration
//configuration相当于连接池
session.close();
}

  Cariteria只是对于criteria的方法进行对于sql语句的控制,这样整个开发过程及其检索;

使用离线查询

@Test	//测试离线查询
public void test04(){
DetachedCriteria dc=DetachedCriteria.forClass(Order.class);
dc.add(Restrictions.between("id", 10, 20));
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
Criteria criteria = dc.getExecutableCriteria(session);
List list = criteria.list();
System.out.println(list);
bt.commit();
session.close();
}

  多表关联查询

    交叉连接

    内连接

      显式内连接  inner join with(where) 

       @Test	//测试显式连接查询
public void test05(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
          // 表一 inner join 表二
String hql="from Customer c inner join c.orders";//"from Customer c inner join c.orders with c.id=1"
Query query = session.createQuery(hql);
List<Object[]> list = query.list();
for (Object[] objects : list) {
for (Object obj : objects) {
System.out.println(obj);
}
}
//操作
bt.commit();
session.close();
}

      隐式内连接

          隐式内连接: 使用 "逗号"将表分开,使用 WHERE 来消除迪卡尔积

	@Test	//测试隐式内连接查询
public void test06(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
String hql="from Order o where o.c.id=1";
Query query = session.createQuery(hql);
List<Order> list = query.list();
for (Order o : list) {
System.out.println(o);
}
//操作
bt.commit();
session.close();
}

      迫切连接

迫切内连接得到的结果是直接封装到 PO 类中,而内连接得到的是 Object[]数组,数组中封
装的是 PO 类对象。
@Test //测试迫切内连接查询
public void test08(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
String hql="from Order o inner join fetch o.c";
Query query = session.createQuery(hql);
List<Order> list = query.list();
for (Order o : list) {
System.out.println(o);
}
//操作
bt.commit();
session.close();
}

    外连接

      左外连接

        @Test	//测试左外连接查询
public void test09(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
String hql="from Customer c left outer join c.orders";
Query query = session.createQuery(hql);
List<Object[]> list = query.list();
for (Object[] objects : list) {
for (Object obj : objects) {
System.out.println(obj);
}
}
//操作
bt.commit();
session.close();
}

      迫切左外连接

        @Test	//测试左迫切外连接查询
public void test10(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
String hql="from Order o left outer join fetch o.c ";
Query query = session.createQuery(hql);
List<Order> list = query.list();
for (Order o : list) {
System.out.println(o);
}
//操作
bt.commit();
session.close();
}

      右外连接

	@Test	//测试左外连接查询
public void test11(){
Session session = HibernateUtils.getSession();
Transaction bt = session.beginTransaction();
String hql="from Customer c right outer join c.orders";
Query query = session.createQuery(hql);
List<Object[]> list = query.list();
for (Object[] objects : list) {
for (Object obj : objects) {
System.out.println(obj);
}
}
//操作
bt.commit();
session.close();
}

  

hibernate之查询的更多相关文章

  1. hibernate模糊查询

    hibernate模糊查询-Restrictions.ilike & Expression.like Criteria criteria = session.createCriteria(Ta ...

  2. Hibernate的查询方式总结

    Hibernate的查询方式大体有三种,分别是HQL QBC和SQL三种.在网上查阅一一些资料,做了一个简单的总结. 1. SQL sql 是面向数据库表查询,from 后面跟的是表名,where 后 ...

  3. atitit。 hb Hibernate sql 查询使用

    atitit. hb  Hibernate sql 查询使用 #----------返回list<map>法..这个推荐使用.      q.setResultTransformer(Tr ...

  4. Hibernate高级查询QBC条件设置——Restrictions用法 引自:http://www.cnblogs.com/evon168/archive/2010/10/29/1863059.html

    方法说明 方法 说明 Restrictions.eq = Restrictions.allEq 利用Map来进行多个等于的限制 Restrictions.gt > Restrictions.ge ...

  5. Hibernate HQL查询:

    Hibernate HQL查询:Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Lanaguage)查询提供了更加丰富的和灵活的查 ...

  6. Hibernate HQL查询语句总结

    Hibernate HQL查询语句总结 1. 实体查询:有关实体查询技术,其实我们在先前已经有多次涉及,比如下面的例子:String hql="from User user ";L ...

  7. Hibernate的查询,二级缓存,连接池

    Hibernate的查询,二级缓存,连接池 1.Hibernate查询数据 Hibernate中的查询方法有5中: 1.1.Get/Load主键查询 使用get或者load方法来查询,两者之间的区别在 ...

  8. hibernate sql查询转换成VO返回list

    hibernate sql查询转换成VO @Override public List<FenxiVo> getTuanDuiFenxiList(FenxiVo FenxiVo,Intege ...

  9. Struts2学习笔记NO.1------结合Hibernate完成查询商品类别简单案例(工具IDEA)

    Struts2学习笔记一结合Hibernate完成查询商品类别简单案例(工具IDEA) 1.jar包准备 Hibernate+Struts2 jar包 struts的jar比较多,可以从Struts官 ...

  10. Hibernate【查询、连接池、逆向工程】

    前言 在Hibernate的第二篇中只是简单地说了Hibernate的几种查询方式....到目前为止,我们都是使用一些简单的主键查询阿...使用HQL查询所有的数据....本博文主要讲解Hiberna ...

随机推荐

  1. Logback报错 no applicable action for [Encoding], current ElementPath is [[configuration][appender][Encoding]]

    老版本是0.9,移到springboot项目,解决办法,删除xml配置文件节点<Encoding>UTF-8</Encoding>

  2. mongodb导入csv结构化数据

    csv数据样本 "103238704","","-jmyuncker@aol.com-","-r4Vp5iL2VbM=-" ...

  3. threejs 世界坐标转化为屏幕坐标

    网站: http://www.yanhuangxueyuan.com/Three.js_course/screen.html 方法.project 通过Vector3对象的方法project,方法的参 ...

  4. 如何将你拍摄的照片转换成全景图及六面体(PTGui)

    在完成全景照片的拍摄之后,接下来,我们需要的是进行全景图的拼接.全景图片分为两种类型1.立方体全景图(6面体)制作全景时通常使用该种格式 如下图 2.球形图(2:1的单张全景图片)2:1全景图宽高比例 ...

  5. c#程序设计原则

    单一职责 开闭原则:对扩展开放,对修改封闭. 方法 的职责,一个方法做的事越多,造成问题的可能性会增加. 解决的方法1:就是分拆2:写单独类

  6. 4N - 素数回文

    xiaoou33对既是素数又是回文的数特别感兴趣.比如说151既是素数又是个回文.现在xiaoou333想要你帮助他找出某个范围内的素数回文数,请你写个程序找出 a 跟b 之间满足条件的数.(5 &l ...

  7. Vim 基本配置

    1.关闭vi的一致性模式 set nocompatible 2.配置backspace的工作方式 set backspace=indent,eol,start 3.显示行号 set number 4. ...

  8. 学习C语言以及C语言基础调查

    学习声乐的心得 你有什么技能比大多人(超过90%以上)更好?   就我个人而言,在所有的兴趣之中,做得比较好的应该属于声乐. 针对这个技能的获取你有什么成功的经验?   我对于声乐处始于兴趣,成功的经 ...

  9. Python之路(第二篇):Python基本数据类型字符串(一)

    一.基础 1.编码 UTF-8:中文占3个字节 GBK:中文占2个字节 Unicode.UTF-8.GBK三者关系 ascii码是只能表示英文字符,用8个字节表示英文,unicode是统一码,世界通用 ...

  10. 数据结构和Java集合

    list接口,可重复,有序的.list有arrayList,因为是数组结构,适合用在数据的查询,linkedList,因为是链表结构,适合用在增删操作.数组如果增删的话,需要后面的元素都往前或者往后移 ...