`
82826200
  • 浏览: 13762 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

hibernate查询

阅读更多
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);
   }
}
}
分享到:
评论

相关推荐

    struts+hibernate查询所有记录

    ### Struts+Hibernate查询所有记录 #### 一、概述 在Java Web开发中,Struts与Hibernate是非常流行的框架组合,用于构建复杂的企业级应用。本文将详细介绍如何利用Struts和Hibernate来实现对Oracle数据库中所有...

    通用的hibernate查询

    【hibernate查询详解】 Hibernate,作为一款强大的Java对象关系映射(ORM)框架,极大地简化了数据库操作。它允许开发者使用面向对象的方式来处理数据库,从而避免了传统的JDBC编码方式带来的复杂性。本篇文章将...

    Hibernate查询练习小例子

    利用MYSQL数据库提供的样例数据库world建立的查询小例子。已经建立好了数据库对应的...本项目主要是为了练习使用Hibernate查询数据库。如果有什么问题可以发站内信或者邮件asddf14@hotmail.com。我会尽量解答一下~~~

    Hibernate查询语言HQL.PPT

    Hibernate 查询语言 HQL Hibernate 查询语言 HQL 是一种面向对象的查询语言,用于检索对象。它提供了灵活多样的查询机制,包括导航对象图、通过标识符检索、使用 HQL 检索对象、使用 Hibernate 条件 API 和使用本地...

    Hibernate查询映射试验

    本实践项目“Hibernate查询映射试验”旨在通过一系列示例帮助开发者掌握Hibernate中的查询映射技术,包括HQL(Hibernate Query Language)和Criteria API。 首先,Hibernate的核心是对象关系映射(ORM),它允许...

    hibernate查询缓存1

    在深入探讨Hibernate查询缓存之前,我们先了解一下Hibernate的基础概念。Hibernate是一个强大的Java持久化框架,它简化了数据库操作,提供了对象关系映射(ORM)功能。在Hibernate中,对象的状态分为瞬时态、持久态...

    hibernate查询代码

    最后,`hibernate查询`这个压缩包可能包含了一些示例代码和配置文件,用于演示如何在Java项目中实现上述查询方式。通过分析这些文件,你可以更好地理解Hibernate查询的工作原理,并将其应用到自己的项目中。 总之,...

    Hibernate查询缓存及实现.PPT

    【标题】:“Hibernate查询缓存及实现.PPT” 【描述】:“Hibernate查询缓存及实现.PPT” 在本文中,我们将深入探讨Hibernate框架中的查询缓存机制及其实施步骤,这是一项旨在提高应用程序性能的重要功能。查询...

    Hibernate查询语言HQL

    Hibernate查询语言HQL

    Hibernate查询语句写在配置文件中

    【标题】:“Hibernate查询语句写在配置文件中” 【正文】: Hibernate 是一个流行的 Java 应用程序框架,主要用于简化数据库操作。它提供了一种对象关系映射(ORM)机制,将数据库操作转化为对 Java 对象的操作,...

    hibernate查询、连接池、二级缓存

    在“hibernate查询、连接池、二级缓存”这个主题中,我们将深入探讨这三个关键概念。 首先,让我们来了解**Hibernate查询**。Hibernate 提供了丰富的查询方式,包括HQL(Hibernate Query Language)和Criteria API...

    HQL Hibernate查询语言

    HQL Hibernate查询语言,HQL的学习和参考的文档,开发必备。

    Hibernate_query查询数据表中的一个字段.

    Hibernate提供了一种灵活的查询语言——HQL(Hibernate Query Language),以及 Criteria 查询和 Criteria API,它们都可以用来获取数据表中的特定字段。 二、Hibernate配置 在使用Hibernate进行查询前,首先需要...

    hibernate查询-hql教程

    hibernate查询-hql等教程,对于学习hibernate有很好的帮助。

    hibernate将本地SQL查询结果封装成对象(最终).zip

    Hibernate支持两种类型的查询:原生SQL查询和Hibernate查询语言(HQL)。原生SQL查询允许开发者直接执行SQL语句,而HQL则是面向对象的查询语言,类似于SQL但更接近于Java。 4. 封装SQL查询结果为对象: - `...

    hibernate查询与缓存

    Hibernate查询首先介绍get()和load()方法的区别:get()方法和load()方法的区别主要在于对二级缓存的使用上。load()方法会使用二级缓存,而get()方法在一级缓存没有找到会直接查询数据库,不会去二级缓存中查找。 get...

    注意hibernate查单一字段和查两个以上的字段返回的结果

    "Huikegeneratecodetool"这个文件可能是一个代码生成工具,它能自动生成符合Hibernate查询规则的代码,从而提高开发效率,减少手动编写SQL的错误。 总的来说,理解Hibernate查询中单一字段与多字段的区别对于优化...

Global site tag (gtag.js) - Google Analytics