1. HQL查询

HQL是Hiberante官方推荐的Hibernate检索方式,它使用类似SQL的查询语言,以面向对象的方式从数据库中查询。可以使用HQL查询具有继承、多态和关
联关系的数据。在检索数据时应优先考虑使用HQL方式。
hibernate的session.createQuery()方法是使用HQL语句查询对象的。     
hql:是查询对象的,例如:"from Person",其中from不区分大小写,而Person是区分大小写,因为它是对象。是Person。返回Query对象。执行这条语句后,Hibernate会根据配置文件中所配置的数据库适配器自动生成相应数据库的SQL语句。
sql: select * from person;   from
后面是表名
hql: form
Person;   from
后面是类。可以对类起别名,有两种方法。hql:
from Person p
hql:from
Person
as p
Session s = sessionFactory.openSession();
String strQuery = "from Person where name=:name";
Query query = s.createQuery(strQuery);
query.setString("name", "张三");
List<Person> lst = query.list();
for(Person p : lst){
<span style="white-space:pre"> </span>System.out.println(p);
}

适用情况:常用方法,比较传统,类似jdbc。缺点:新的查询语言,适用面有限,仅适用于Hibernate框架。

2. Criteral查询

Session s = sessionFactory.openSession();
Criteria criteria = s.createCriteria(Person.class);
criteria.add(Restrictions.eq("name", "张三"));
List<Person> lst = criteria.list();
for(Person p : lst){
<span style="white-space:pre"> </span>System.out.println(p);
}

适用情况:面向对象操作,革新了以前的数据库操作方式,易读。缺点:适用面较HQL有限。

3. DetachedCriteria查询

private List<Person> dc(DetachedCriteria dc){
<span style="white-space:pre"> </span>Session s = sessionFactory.openSession();
Criteria criteria = dc.getExecutableCriteria(s);
return criteria.list();
}
DetachedCriteria dc = DetachedCriteria.forClass(Person.class);
dc.add(Restrictions.eq("name", "张三"));
List<Person> lst = dc(dc);
for(Person p : lst){
<span style="white-space:pre"> </span>System.out.println(p);

适用情况:面向对象操作,分离业务与底层,不需要字段属性摄入到Dao实现层。 
缺点:适用面较HQL有限。

4. Example 查询

Person p = new Person();
p.setName("张三");
//p.setName("张%");
Session s = sessionFactory.openSession();
Criteria c = s.createCriteria(Person.class);
Example example = Example.create(p);
example.excludeProperty("age");//排除年龄属性
example.excludeProperty("birthDay");
example.excludeProperty("id");
//example.enableLike();//启用模糊查询
List<Person> list = c.add(example).list();
for(Person p1 : list){
System.out.println(p1);
}

适用情况:面向对象操作。  
缺点:适用面较HQL有限,不推荐。

5.
sql查询

Session s = sessionFactory.openSession();
String strQuery = "select * from person where pname=:name";//条件应为表的属性
Query query = s.createSQLQuery(strQuery).addEntity(Person.class);
//java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to hibernate.entity.Person
query.setString("name", "张三");
List<Person> list = query.list();
for(Person p1 : list){
System.out.println(p1);
}

适用情况:不熟悉HQL的朋友,又不打算转数据库平台的朋友,万能方法  
缺点:破坏跨平台,不易维护,不面向对象,查询条件的属性应和平常的SQL一样,采用表的属性。

6. 命名查询

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
'-//Hibernate/Hibernate Mapping DTD 3.0//EN'
'http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd'>
<hibernate-mapping>
<class name="hibernate.entity.Person" table="person">
<id name="id" column="pid"></id>
<property name="name" column="pname"></property>
<property name="birthDay" type="date" ></property>
<property name="age"></property>
</class>
<query name="getPersonByName">
<![CDATA[from Person where name=:name]]>
</query>
</hibernate-mapping>

Session s = sessionFactory.openSession();
Query HQLquery = s.getNamedQuery("getPersonByName");
HQLquery.setString("name", "张三");
List<Person> list = HQLquery.list();
for(Person p1 : list){
System.out.println(p1);
}

适用情况:万能方法,有点像ibatis轻量级框架的操作,方便维护。 
缺点:不面向对象。基于hql和sql,有一定缺陷。



上述六种查询方法,HQL查询,SQL查询,命名查询比较好用。

Hibernate查询方法总结的更多相关文章

  1. Hibernate 查询方法

    1.简单查询: public User select(User user) { User newUser; try { newUser = (User) session.get(User.class, ...

  2. J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())

    J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())   当我们使用Hibernate进行数据的CRUD操作时,利用模版进行操作不失为一种方法. ...

  3. hibernate查询竟然有6种方法

    hibernate查询的6种方法 1.HQL查询 2.对象化查询Criteria方法 3.动态查询DetachedCriteria 4.例子查询 5.sql查询 6.命名查询 1.HQL查询 stat ...

  4. Hibernate查询出现java.lang.IllegalArgumentException异常解决方法

    Hibernate查询出现java.lang.IllegalArgumentException. 异常信息如下:java.lang.IllegalArgumentException        at ...

  5. Hibernate查询对象的方法浅析

    Hibernate 查询对象是根据对象的id查询的,只要你有id (id唯一),则无论你是否其他字段与传过来的对象一致,都会查到该id在数据库对应的对象.若是在关联查询中,所关联表的id为空,即所查表 ...

  6. Hibernate查询

    HIbernate查询 使用get方法 使用get方法通过持久类名和ID号查找一个对象Stu instance = (Stu) getsession() .get("com.lovo.po. ...

  7. hibernate查询方式

    hibernate查询方式:1.本地SQL查询 2.HQL查询 3.QBC查询 HQL查询:是面向对象的查询语言,是使用最广的一种查询方法 QBC查询:Query by Criteria是一套接口来实 ...

  8. 六种方式实现hibernate查询

    最近在学习Hibernate的基本内容,刚好在项目中有用到,基本上都是用到哪就学哪. 今天看看六种方式实现hibernate查询......... 分别是HQL查询,对象化查询Criteria方法,动 ...

  9. 记录使用Hibernate查询bean中字段和数据库列类型不匹配问题

    今天在工程中遇到Hibernate查询的时候,bean中的字段和数据库中的字段不符合(bean中有pageTime字段,但是数据库中没有此列)报错问题. 具体问题环境: 在auto_off表中,off ...

随机推荐

  1. SQL(笔试题)网站上的广告位是轮播的,每天某一广告位最多可轮播的广告数量是有限制的,比如A广告位,每天只能轮播三个广告,但销售人员在销售广告位时并不考虑此限制,要求查询出合同表中,超过广告位轮播数量的合同。

    合同表 Orders OrderID Positioncode Startdate Enddate 1 A 2006-11-01 2006-11-03 2 C 2006-11-02 2006-11-0 ...

  2. Prism vs MvvmCross

    Prism vs MvvmCross 在上一篇Xamarin开发环境及开发框架初探中,曾简单提到MvvmCross这个Xamarin下的开发框架.最近又评估了一些别的,发现老牌Mvvm框架Prism现 ...

  3. skiplist 跳表(1)

    最近学习中遇到一种新的数据结构,很实用,搬过来学习. 原文地址:skiplist 跳表   为什么选择跳表 目前经常使用的平衡数据结构有:B树,红黑树,AVL树,Splay Tree, Treep等. ...

  4. WinterCamp 2015 总结

    这次WC2015确实有很多遗憾,特别是考试的时候犯的低级错误,由于我没有看到第三题每个点输出不全可以得小分,对于又没跑出来的点,我都根本没有上交.这确实是一个很悲伤的事情,但是也给我了足够时间去反思. ...

  5. bzoj 3053 HDU 4347 : The Closest M Points kd树

    bzoj 3053 HDU 4347 : The Closest M Points  kd树 题目大意:求k维空间内某点的前k近的点. 就是一般的kd树,根据实测发现,kd树的两种建树方式,即按照方差 ...

  6. Http 与 Socket 区别

    HTTP:超文本传输协议,首先它是一个协议,并且是基于TCP/IP协议基础之上的应用层协议.TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,HTTP是应用层协议,主要解决如何包装数据.HT ...

  7. http://www.ibm.com/developerworks/cn/opensource/os-cn-cas/

    http://www.ibm.com/developerworks/cn/opensource/os-cn-cas/

  8. [转贴]JAVA :RESTLET开发实例(一)基于JAX-RS的REST服务

    RESTLET介绍 Restlet项目为“建立REST概念与Java类之间的映射”提供了一个轻量级而全面的框架.它可用于实现任何种类的REST式系统,而不仅仅是REST式Web服务. Restlet项 ...

  9. [置顶] 【Git入门之一】Git是神马?

    1.Git是神马? 一个开源的分布式版本控制系统,可以有效的高速的控制管理各种从小到大的项目版本.他的作者就是大名鼎鼎的Linux系统创始人Linus. 2.分布式又是神马? 先看看集中式.简单说来, ...

  10. POJ_1631_Bridging_Signals_(动态规划,LIS)

    描述 http://poj.org/problem?id=1631 铁路左右相连,要求去掉一些边,使得剩下的边不交叉,求剩余边数的最大值. Bridging signals Time Limit: 1 ...