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. uva 812 Trade on Verweggistan

    题意: 给w个货架, 每个货架上有bi个货物, 每次只能拿最上面的货物, 每个货物有个价值, 所有货物的售价均为10. 问:能获得的最大利润, 以及能获得这个利润需要多少个货物. (有多种组合时只需输 ...

  2. 【转载】Using the Web Service Callbacks in the .NET Application

    来源 This article describes a .NET Application model driven by the Web Services using the Virtual Web ...

  3. 关于django Models的个人理解和related_name的使用

    作为一个新人(刚刚大学还没有毕业就出来实习,可以说是真的什么都不知到,什么都要重新学,但是这样真的可以锻炼自己的意志力和能力).现在在公 司是前端和后端一起坐,所以要学的东西是真的多的让人想不到.在学 ...

  4. python面向对象高级编程

    正常情况下,当我们定义了一个class,创建了一个class的实例后,我们可以给该实例绑定任何属性和方法,这就是动态语言的灵活性.先定义class: >>> class Studen ...

  5. Java ,单实例 多线程 ,web容器,servlet与struts1-2.x系列,线程安全的解决

    1.Servlet是如何处理多个请求同时访问呢? 回答:servlet是默认采用单实例,多线程的方式进行.只要webapp被发布到web容器中的时候,servlet只会在发布的时候实例化一次,serv ...

  6. Mysql Partition 理论知识总结

    简述: 本文内容主要 Giuseppe Maxia 曾在Mysql Conference & Expo 2010发表关于 <Mysql Partition in Mysql 5.1 &a ...

  7. 李洪强漫谈iOS开发[C语言-029] - 关系运算符

  8. OA学习笔记-002-Sruts2.1配置

    一.jar commons-fileupload-1.2.1.jarcommons-io-1.3.2.jarfreemarker-2.3.15.jarognl-2.7.3.jarstruts2-cor ...

  9. 好看的UI设计网站 www.ui.cn 和 插画网站 www.pixiv.net 千图网,界面很不错~

    http://www.ui.cn/?t=share#project http://www.pixiv.net/ http://www.flaticon.com/ www.58pic.com 那张 给人 ...

  10. 最新ps cs6序列号 永久免费可用

    一. 序列号 除非是从官方购买,从其它任何途径得到的序列号(包括网上流传的注册机生成的)都是不能通过联网验证的,必须使用破解补丁,或是通过修改hosts文件的方式来激活.因此,除了正版,不存在所谓的“ ...