博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hibernate查询_HQL_EJBQL_QBC_QBE
阅读量:4603 次
发布时间:2019-06-09

本文共 2551 字,大约阅读时间需要 8 分钟。

查询按功能强弱可以分为以下几种:

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更加符合面向对象编程(仅此而已)。

转载于:https://www.cnblogs.com/zl520/p/9973773.html

你可能感兴趣的文章
Wireless Network 并查集
查看>>
51nod 1019 逆序数
查看>>
20145202马超《JAVA》预备作业1
查看>>
云推送注意(MSDN链接)
查看>>
IDEA 生成 jar 包
查看>>
加减乘除混合版
查看>>
linux基础6-bash shell编程
查看>>
掌握这几种微服务模式助你成为更出色的工程师
查看>>
为什么很多语言选择在JVM上实现
查看>>
CSS Reset CSS Framework
查看>>
LeetCode算法扫题系列19
查看>>
nginx获取经过层层代理后的客户端真实IP(使用正则匹配)
查看>>
YII实现dropDownList 联动事件
查看>>
为什么JavaScript里面0.1+0.2 === 0.3是false
查看>>
docker swarm集群搭建
查看>>
BZOJ 1303: [CQOI2009]中位数图 问题转化_扫描_思维
查看>>
SP1026 FAVDICE - Favorite Dice 数学期望
查看>>
NodeJS、NPM安装配置步骤(windows版本)
查看>>
【矩阵+十进制快速幂】[NOI2013]矩阵游戏
查看>>
Java一个简单的文件工具集
查看>>