Castle ActiveRecord学习(五)使用HQL语句查询
来源:http://www.cnblogs.com/Terrylee/archive/2006/04/12/372823.html
一.HQL简单介绍
HQL全名是Hibernate Query Language,它是一种完全面向对象的查询语言。
1.from 子句
from UserInfo
from UserInfo as userinfo
from UserInfo userinfo
UserInfo:是类名称,而不是[ActiveRecord(Table = "UserInfo")]中指定的UserInfo
2.select 子句
select Name,Author from Blog
也可以使用elements函数来查询一个集合
select elements(blog.Posts) from Blog blog
3.使用聚合函数
HQL中也可以使用一些聚合函数
select count(*) from Blog blog
select count(elements(blog.Posts)) from Blog blog
HQL支持的聚合函数有
avg(...),sum(...),min(...),max(...),count(*),count(...), count(distinct ...), count(all...)
4.Where子句
from Blog blog where blog.Name = 'test'
from Blog blog where blog.Name is not null
//根据标题 模糊查询
public static ThemeInfo[] FindBySubject(string _content)
{
SimpleQuery query = new SimpleQuery(typeof(ThemeInfo), @"from ThemeInfo themeInfo where themeInfo.Subject like ?", "%" + _content + "%");
return (ThemeInfo[])ExecuteQuery(query);
}
5.自定义查询
在实际开发中,我们所面对的查询远不止上面所说得这么简单,有时候我们需要处理一些自定义的参数,或者执行自定义的查询语句,这时需要我们编写自定义的ActiveRecord查询。
首先要添加一个类,让它继承于基类ActiveRecordBaseQuery,并覆写CreateQuery()方法(或者实现IactiveRecordQuery接口),如下例所示:
using Castle.ActiveRecord;
using NHibernate;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace Models
{
public class QueryWithNamedParameters : ActiveRecordBaseQuery
{
private string _Name = null;
private int _maxResults = 2; public QueryWithNamedParameters()
: base(typeof(UserInfo))
{ } public string Name
{
get { return _Name; }
set { _Name = value; }
} public int MaxResults
{
get { return _maxResults; }
set { _maxResults = value; }
} protected override IQuery CreateQuery(ISession session)
{
String hql = "from UserInfo userinfo";
if (!string.IsNullOrEmpty(_Name))
{
hql += " where userinfo.Name like :author";//设置查询语句
} IQuery q = session.CreateQuery(hql);
if (!string.IsNullOrEmpty(_Name))
{
q.SetString("author", "%" + _Name + "%");//设置查询参数
}
q.SetMaxResults(_maxResults);
return q;
}
}
}
使用:
//自定义查询
public static ArrayList GetThreeEntityByName(string Name)
{
QueryWithNamedParameters q = new QueryWithNamedParameters();
q.Name = Name;
q.MaxResults = 3;
return (ArrayList)ExecuteQuery(q);
} //自定义查询
StringBuilder htmlStr3 = new StringBuilder();
ArrayList list3 = Models.UserInfo.GetThreeEntityByName("jay"); foreach (Models.UserInfo item in list3)
{
htmlStr3.Append(" 编号:" + item.ID + " 名称:" + item.Name + "<br />");
}
Literal4.Text = htmlStr3.ToString();
6.使用CallBack自定义查询
/// <summary>
/// 通过CallBack执行
/// </summary>
/// <param name="author"></param>
/// <returns></returns>
public static UserInfo[] GetUserByName(string Name)
{
return (UserInfo[])Execute(typeof(UserInfo), new NHibernateDelegate(GetDataByNameCallback), Name);
} private static object GetDataByNameCallback(ISession session, object instance)
{
// 创建查询
IQuery query = session.CreateQuery("from UserInfo userinfo where userinfo.Name like :author"); // 设置参数
query.SetString("author", "%" + Convert.ToString(instance) + "%"); // 获取结果
IList results = query.List(); // 转化结果为Array
UserInfo[] users = new UserInfo[results.Count];
results.CopyTo(users, 0); // 返回结果
return users;
}
调用:
//自定义查询2
StringBuilder htmlStr4 = new StringBuilder();
Models.UserInfo[] list4 = Models.UserInfo.GetUserByName("jay"); foreach (Models.UserInfo item in list4)
{
htmlStr4.Append(" 编号:" + item.ID + " 名称:" + item.Name + "<br />");
}
Literal5.Text = htmlStr4.ToString();
7.如果不使用HQL语句查询,可以配置使用Sql查询:
SimpleQuery<RecruitmentInfo> query = new SimpleQuery<RecruitmentInfo>(QueryLanguage.Sql,hql,paras[]);
如果需要查询前几条 sql:select top 10 * from TableName;hql使用:query.SetQueryRange(BeginIndex, PageSize);//设置从哪一条开始,读取多少条
Castle ActiveRecord学习(五)使用HQL语句查询的更多相关文章
- Castle ActiveRecord学习实践
Castle是针对.NET平台的一个开源项目,从数据访问框架ORM到IOC容器,再到WEB层的MVC框架.AOP,基本包括了整个开发过程中的所有东西,为我们快速的构建企业级的应用程序提供了很好的服务. ...
- hql语句查询实体类采用list方法的返回结果集
在hibernate中,用hql语句查询实体类,采用list方法的返回结果为一个List,该List中封装的对象分为以下三种情况:1.查询全部字段的情况下,如"from 实体类", ...
- hql语句查询
这篇随笔将会记录hql的常用的查询语句,为日后查看提供便利. 在这里通过定义了三个类,Special.Classroom.Student来做测试,Special与Classroom是一对多,Class ...
- Castle ActiveRecord学习(三)数据映射及特性描述
Model中的Demo: using Castle.ActiveRecord; using Castle.ActiveRecord.Queries; using System; using Syste ...
- 使用Query进行HQL语句查询和SQL语句查询
HQL的语法比较简单,与普通SQL的区别之处是针对对象的不同,在查询语句中将sql中的表名替换成了sql中的持久化类名,因为hibernate机制是基于对象进行查询的. 不带参数的查询,语句是“fro ...
- Castle ActiveRecord学习(六)数据验证
参考.来源:http://www.cnblogs.com/Terrylee/archive/2006/04/13/374173.html https://github.com/castleprojec ...
- Castle ActiveRecord学习(二)配置、引用、程序启动
来源:http://www.cnblogs.com/zxj159/p/4082987.html 配置数据库驱动: Model层引用:Castle.ActiveRecord.dll.NHibernate ...
- Castle ActiveRecord学习(一)简介
简介 来源:http://www.cnblogs.com/zxj159/p/4082987.html 一.Active Record(活动记录)模式 Active Record是业务逻辑层中(< ...
- Castle ActiveRecord学习(四)延迟加载、分页查询、where条件
一.延迟加载 //用户发布的主题,一对多:Table:外键表:ColumnKey:外键:Lazy:延迟加载:Cascade:级联操作(级联删除) [HasMany(typeof(ThemeInfo), ...
随机推荐
- ElasticSearch 索引模块——集成IK中文分词
下载插件地址 https://github.com/medcl/elasticsearch-analysis-ik/tree/v1.10.0 对这个插件在window下进行解压 用maven工具对插件 ...
- ajax 方法的使用以及方法中各参数的含义
由于近来经常在项目中使用 ajax 这个函数,在工作之余自己查找了相关的资料,并总结了 ajax 方法的使用,以及方法中各个参数的含义,供大家学习参考使用 type: 要求为String类型的参数,请 ...
- C# 日志记录工具类--LogHelper.cs测试
C# 日志记录工具类:(适用于不想使用log4j等第三方的Log工具的时候,希望自己写个简单类实现)LogHelper.cs内容如下: using System; using System.Diagn ...
- selenium+python自动化98--文件下载弹窗处理(PyKeyboard)
前言 在web自动化下载操作时,有时候会弹出下载框,这种下载框不属于web的页面,是没办法去定位的(有些同学一说到点击,脑袋里面就是定位!定位!定位!) 有时候我们并不是非要去定位到这个按钮再去点击, ...
- 粗解python的@classmethod和@staticmethod及普通实例方法
引言: 使用不同的函数定义方法,可以使得函数定义更加有效而且易于维护 本文为博主原创,根据本人自己的理解整理而成,若有不准确的地方,希望能留言告知以免误导他人: 首先进一段代码,来直观感受一下不同类型 ...
- uva-301-枚举-组合
题意:从A市到B市有n个站点,限制火车上搭乘的乘客数目,每个站点都从有一些乘车的订单,订单信息 从x到y,乘客m人,求解最大的收入是多少 最多7个站,22个订单 选取订单的时候没有顺序问题,所以不是全 ...
- 使用SharedPreferences存储数据
SharedPreferences把数据保存在指定名称的XML文件中,文件地址在/data/data/包名/Shared_Prefs/文件夹中,具体是通过map形式保存. 保存数据: SharedPr ...
- JAVA servlet 上传文件(commons-fileupload, commons-io)
<1>获取二进制文件流并输出 InputStream inputStream = request.getInputStream(); BufferedReader reader = new ...
- leetcode937
public class Solution { public string[] ReorderLogFiles(string[] logs) { var list1 = new List<str ...
- JAVA 模拟瞬间高并发
如何模拟一个并发?当时我的回答虽然也可以算是正确的,但自己感觉缺乏实际可以操作的细节,只有一个大概的描述. 当时我的回答是:“线程全部在同一节点wait,然后在某个节点notifyAll.” 面试官: ...