grails的criteria和hql查询

grails在查询方面也保留了hibernate的hql和criteria查询功能,hql自然不必多说基本不会有什么变化,grails的criteria查询在hibernate上面做了微调使用起来更加方便了,这次就这两个特点分享下我这几天的所学

1.grails的criteria查询

先来个简单的,通过criteria来构造一个in条件查询

def  useCriteria2(){
        def c=CityInfo.createCriteria()
        def result=c.list{
           ‘in‘("id",[1,2,3])
        }
        Iterator<CityInfo> it=result.iterator()
        def buf=new StringBuffer();
        while(it.hasNext()){
            CityInfo info=it.next()
            buf.append(info.getName()+"-")
        }
        render buf.toString()
    }

这里查询的是id在1,2,3这个集合里城市信息,来看看结果:

接下来弄个稍微复杂一点的,弄个范围查询和模糊查询综合起来的例子

def  useCriteria(){
        def c=CityInfo.createCriteria()
        def result=c.list{
             gt("id",3)
             and{
                 like("name","%兴%")
             }
        }
        Iterator<CityInfo> it=result.iterator()
        def buf=new StringBuffer();
        while(it.hasNext()){
            CityInfo info=it.next()
            buf.append(info.getName()+"-")
        }
        render buf.toString()
    }

and里面可以写多个条件,当然了如果是or条件也可以这样用,上面的程序运行效果如下:

2.grails的hql查询

def useHql(){
        def hql="from CityInfo where id>:id  and code in:code"
        def result=CityInfo.executeQuery(hql,["id":2,code:["NB","NJ"]])
        response.setHeader("Content-Type","text/html; charset=UTF-8")
        [result:result]
    }

这个查询相信大家都看得懂,这里我想稍微做下扩展,应为默认情况下grails使用gsp或者jsp作为视图页面,个人觉得学习gsp会增加学习成本,jsp的话也不是太方便,velocity用的也不多,因此打算使用freemarker来作为视图。

由于grails并没有默认支持freemarker,因此要在项目里添加这个插件,由于版本的差异安装插件的方式也有所不同

(1)grails 1.x的版本

使用命令:grails install-plugin  插件的路径

(2)grails 2.x的版本

打开BuildConfig.groovy,找到plugins节点,在花括号的最后加上 compile ":freemarker:0.1.1",如下所示:

图上的0.1.2是为了能让大家看到那个黄色的提示改的,用0.1.1版本就足够我们用了,加上之后点一下红色箭头所指的地方或者重启下项目,插件就安装成功了

接下来就是jar包了,我们要在lib下面加上freemarker的jar包,这个jar包到struts2里面可以找到,这步完成后如果freemarker插件文件有编译错误的话就要把freemarker的jar包引入构建路径,如下所示:

到这一步为止,我们就可以使用freemarker了,上面的useHql的视图页面如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>查询结果</title>
</head>
<body>
<#list result as item>
    ${item.id}, ${item.name}<br/>
</#list>
</body>
</html>

这里的result是返回的map对应的key,这样子数据就显示出来了

安装插件的时候要注意,如果版本选不对,那么一切工作都是徒劳。官网说的那个0.4版本我试过貌似用不成

grails的criteria和hql查询,布布扣,bubuko.com

时间: 2024-08-09 19:52:26

grails的criteria和hql查询的相关文章

grails的criteria实现复合查询并实现结果分页

def search = {         if(!params.max) params.max = 10         if(!params.offset) params.offset = 0         def searchClosure =  {             if(params.categoryName) {                 category{                     eq('categoryName', params.categoryN

Hibernate框架之HQL查询与Criteria 查询的区别

Hibernate框架提供了HQL查询和Criteria 查询.下面对这两种查询分别做个例子.也好对这两种查询方法有个大概的了解.就用房屋信息表做例子,查询所有房屋信息. HQL语句查询所有房屋信息: /* * 查询所有房屋 * * (non-Javadoc) * @see Dao.HouseDao#selecthouse() */ public List<House> selecthouse() { // TODO Auto-generated method stub //获取连接 Sess

hibernate框架学习笔记7:HQL查询、Criteria查询

HQL查询:hibernate独有的查询语言 适用于不复杂的多表查询 示例: 实体类: package domain; public class Customer { private Long cust_id; private String cust_name; private String cust_source; private String cust_industry; private String cust_level; private String cust_linkman; priv

Hibernate(十二):HQL查询(一)

概述 Hibernate提供了以下几种检索对象的方式 1)导航对象图检索方式:根据已经加载的对象导航到其他对象: 2)OID检索方式:按照对象的OID来检索对象: 3)HQL检索方式:使用面向对象的HQL查询语言: 4)QBC检索方式:使用QBC(Query By Criteria)API来检索对象.这种API封装了基于字符串形式的查询语句,提供了更加面向对象的查询接口. 5)本地SQL检索的方式:使用本地数据的SQL查询语句. HQL(Hibernate Query Language)面向对象

Hibernate HQL查询:

Hibernate HQL查询:Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Lanaguage)查询提供了更加丰富的和灵活的查询特性,因此Hibernate将HQL查询方式立为官方推荐的标准查询方式,HQL查询在涵盖Criteria查询的所有功能的前提下,提供了类似标准SQL语句的查询方式,同时也提供了更加面向对象的封装.完整的HQL语句形势如下:Select/update/delete…… from …… where …

NHibernate系列文章二十二:NHibernate查询之HQL查询(附程序下载)

摘要 NHibernate提供了多种查询方式,最早的HQL语言查询.Criteria查询和SQL Query,到NHibernate 3.0的Linq NHibernate,NHIbernate 4.0又添加了Query Over.每种方式各有优缺点,任何一个SQL查询可以使用任何查询方式查询.根据程序员每种方式掌握的情况,可以使用不同的查询方式.本篇文章介绍HQL语言查询.HQL(Hibernate Query Language)是NHibernate特有的面向对象查询语言,他具有继承.多态的

第六讲(二) Hibernate HQL查询

HQL查询:Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Lanaguage)查询提供了更加丰富的和灵活的查询特性,因此Hibernate将HQL查询方式立为官方推荐的标准查询方式,HQL查询在涵盖 Criteria查询的所有功能的前提下,提供了类似标准SQL语句的查询方式,同时也提供了更加面向对象的封装.完整的HQL语句形势如下:Select/update/delete…… from …… where …… group b

Hibernate(九)HQL查询

一.Hibernate提供的查询方式 OID查询方式:主键查询.通过get()或者load()方法加载指定OID的对象查询结果为一个 HQL查询方式:通过Query接口使用HQL语言进行查询 QBC查询方式:通过Criteria等接口和类进行是查询 本地SQL查询方式:使用原生的SQL语言进行查询 对象导航查询方式:通过已经加载的对象,导航到其关联对象 其中HQL和QBC是Hibernater提供的专业的查询方式 HQL查询方式为官方推荐的标准查询方式 二.HQL查询简述 HQL:Hiberna

HQL查询语句

查询语言 Hibernate 查询语言(HQL)是一种面向对象的查询语言,类似于 SQL,但不是去对表和列进行操作,而是面向对象和它们的属性. HQL 查询被 Hibernate 翻译为传统的 SQL 查询从而对数据库进行操作. 尽管你能直接使用本地 SQL 语句,但我还是建议你尽可能的使用 HQL 语句,以避免数据库关于可移植性的麻烦,并且体现了 Hibernate 的 SQL 生成和缓存策略. 在 HQL 中一些关键字比如 SELECT ,FROM 和 WHERE 等,是不区分大小写的,但是