查询按功能强弱可以分为以下几种:
Native SQL > HQL > EJBQL > QBC > QBE

1、Native SQL
Native SQL为数据库系统本身的SQL,里面包含了一些特有的函数等,功能也最为强大。
如:

 1    @Test
 2    public void testHQL_34() {
 3        Session session = sf.openSession();
 4        session.beginTransaction();
 5        //下面查询使用的函数是Session的createSQLQuery
 6        SQLQuery q = session.createSQLQuery("select * from category limit 2,4").addEntity(Category.class);
 7        List<Category> categories = (List<Category>)q.list();
 8        for(Category c : categories) {
 9            System.out.println(c.getName());
10        }
11        session.getTransaction().commit();
12        session.close();
13        
14    }

2、HQL
Hibernate提供的面向对象查询语言。
如:

 1    @Test
 2    public void testHQL_02() {
 3        Session session = sf.openSession();
 4        session.beginTransaction();
 5        //Category是对象名而不是数据表名
 6        Query q = session.createQuery("from Category c where c.name > 'c5'");
 7        List<Category> categories = (List<Category>)q.list();
 8        for(Category c : categories) {
 9            System.out.println(c.getName());
10        }
11        session.getTransaction().commit();
12        session.close();
13        
14    }

3、EJBQL
与HQL类似,是HQL的一个子集

4、QBC
Query By Criteria,即带约束/条件的查询
如:

 1    @Test
 2    public void testQBC() {
 3        Session session = sf.openSession();
 4        session.beginTransaction();
 5        //criterion 标准/准则/约束
 6        Criteria c = session.createCriteria(Topic.class) //from Topic
 7                     
 8                     .add(Restrictions.gt("id", 2)) //greater than = id > 2
 9                     .add(Restrictions.lt("id", 8)) //little than = id < 8
10                     .add(Restrictions.like("title", "t_"))
11                     .createCriteria("category")
12                     .add(Restrictions.between("id", 3, 5)) //category.id >= 3 and category.id <=5
13                     ;
14
15        //DetachedCriterea
16        for(Object o : c.list()) {
17            Topic t = (Topic)o;
18            System.out.println(t.getId() + "-" + t.getTitle());
19        }
20        session.getTransaction().commit();
21        session.close();
22        
23    }

5、QBE
Query By Example
如:

 1    @Test
 2    public void testQBE() {
 3        Session session = sf.openSession();
 4        session.beginTransaction();
 5        Topic tExample = new Topic();
 6        tExample.setTitle("T_");
 7        
 8        //创建一个例子对象,然后设置其相应的属性
 9        //QBE仅适合于给特定值的查询
10        Example e = Example.create(tExample)
11                    .ignoreCase().enableLike();
12        //QBC除了添加自己的条件,最后将例子对象e也当成条件添加进来
13        //QBC可以添加给特定值的条件,也可添加给了一定范围的条件
14        Criteria c = session.createCriteria(Topic.class)
15                     .add(Restrictions.gt("id", 2))
16                     .add(Restrictions.lt("id", 8))
17                     .add(e)
18                     ;
19        //from Topic t where t.id>2 and t.id<8 and t.title like 'T_'
20                     
21        
22        for(Object o : c.list()) {
23            Topic t = (Topic)o;
24            System.out.println(t.getId() + "-" + t.getTitle());
25        }
26        session.getTransaction().commit();
27        session.close();
28        
29    }

以上几种方法,其中QBC、QBE更加符合面向对象编程(仅此而已)。

Hibernate查询_HQL_EJBQL_QBC_QBE的更多相关文章

  1. Hibernate查询

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

  2. Hibernate 查询MatchMode的四种模式

    Hibernate 查询MatchMode的四种模式 MatchMode.START:字符串在最前面的位置.相当于"like 'key%'" MatchMode.END:字符串在最 ...

  3. hibernate查询方式

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

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

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

  5. (十)Hibernate 查询方式

     所有项目导入对应的hibernate的jar包.mysql的jar包和添加每次都需要用到的HibernateUtil.java 第一节:Hibernate 查询方式简介 1,导航对象图查询方式: 2 ...

  6. 六种方式实现hibernate查询

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

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

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

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

    hibernate 查询.二级缓存.连接池 查询: 1) 主键查询 Dept dept =  (Dept) session.get(Dept.class, 12); Dept dept =  (Dep ...

  9. Hibernate查询、连接池、二级缓存

    Hibernate第三天: 1. 对象状态 2. session缓存 3. lazy懒加载 4. 映射 一对一对映射 组件/继承映射 目标: 一.hibernate查询 二.hibernate对连接池 ...

随机推荐

  1. linux文件系统管理的工作原理

    一.系统在初始化时如何识别硬盘 1.系统初始时根据MBR的信息来识别硬盘,其中包括了一些执行文件就来载入系统,这些执行文件就是MBR里前面446bytes里的boot loader 程式,而后面的16 ...

  2. 统计svn 代码提交情况

    统计svn代码提交,使用工具 statsvn.jar 下载地址:http://sourceforge.net/projects/statsvn/ rem 声明一个时间变量 作为文件名 %time:~, ...

  3. 清除sqlserver日志方法(不适合always on)

    清除sqlserver日志方法 --查看数据库的recovery_model_desc类型 SELECT NAME, recovery_model_desc FROM sys.databases -- ...

  4. 不停mysql服务添加从库的两种方式

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库.前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作. ...

  5. 每日英语:Hold On: Reasons For Never Giving Up Your Dream

    Do you remember what you wanted to be when you grew up? Maybe a fireman? A baker? A ballerina? You p ...

  6. 【Java】代理模式,静态代理和动态代理(基于JDK或CGLib)

    当我们需要在一个方法之前或之后添加一段逻辑时,自然会想到使用代理类.代理类帮我们代理了实际类的调用,然后可以在实际调用之前和之后添加一些逻辑,从而不浸入实际类. 拓展:由于代理类能在实际类调用之前和之 ...

  7. [原]零基础学习SDL开发之在Android使用SDL2.0显示BMP图

    关于如何移植SDL2.0到安卓上面来参考我的上一篇文章:[原]零基础学习SDL开发之移植SDL2.0到Android 在一篇文章我们主要使用SDL2.0来加载一张BMP图来渲染显示. 博主的开发环境: ...

  8. NAND FLASH驱动程序

    NAND FLASH是一个存储芯片那么: 这样的操作很合理"读地址A的数据,把数据B写到地址A" 问1. 原理图上NAND FLASH和S3C2440之间只有数据线,     怎么 ...

  9. linux环境变量设置 以及 source命令 Linux 之 /etc/profile、~/.bash_profile 等几个文件的执行过程 Linux 设置环境变量

    定制环境变量  环境变量是和Shell紧密相关的,用户登录系统后就启动了一个Shell.对于Linux来说一般是bash,但也可以重新设定或切换到其它的Shell.环境变量文件:/etc/profil ...

  10. tomcat logs 目录下各日志文件的含义

    tomcat每次启动时,自动在logs目录下生产以下日志文件,按照日期自动备份 localhost.2016-07-05.txt   //经常用到的文件之一 ,程序异常没有被捕获的时候抛出的地方 ca ...