nhibernate入门系列: 使用Criteria载入对象

原创 2007年09月12日 18:32:00
通过CreateCriteria方法, 可以取得一个ICriteria接口, 这个接口用于操作表达式和排序字段. 由CriteriaImpl类实现,此类加有Internal修饰,因此不能在程序集外显示创建, CreateCriteria方法需要一个要加载对象类型的参数.

这里列出ICriteria接口中的一些常用方法:

Add:加入条件表达式(Expression对象),此方法可多次调用以组合多个条件;
AddOrder:加入排序的字段(Order对象);
List:执行查询, 返回满足条件的对象集合。
SetMaxResults:设置返回的最大结果数,可用于分页;
SetFirstResult:设置首个对象返回的位置,可用于分页;
SetTimeout:设置操作的超时值,此值将传递给IDbCommand对象;

Expression(表达式)

Expression类是所有表达式类的祖先. 这是一个抽象(abstract)类, 同时也是一个类工厂(Factory Method模式), 用于创建派生的表达式对象, 用意是很明显的, 隐藏了派生类的细节,使我们可通过一致的方法来创建表达式对象.

下面列出一些Expression中常用的方法:

Eq:得到一个相等判断的表达式, 等同于 propertyName = value;
Gt:得到一个大于判断的表达式, 等同于 propertyName > value;
Like:得到一个相似判断的表达式, 等同于 propertyName like value;
And:得到两个表达式And操作后的表达式, 等同于 expression1 and expression2;
Or:重到两个表达式Or操作后的表达式, 等同于 expression1 or expression2;

更多的Expression请参考相关文档或源代码。

Order(排序)

Order类用于向ICriteria接口提供排序信息. 这个类提供了两个静态方法, 分别是Asc和Desc, 顾名思义就是创建升序和降序的Order对象.
例如要取得一个按更新日期(Updated)降序的Order对象, 使用Order.Desc("Updated")就可以了.

示例

下面以几个例子来说明使用Criteria载入对象的用法:

1. 取得用户名(Username)为billy的用户对象:

Expression ex = Expression.Eq( "Username", "billy" ); // ( Username = 'billy' )
IList users = session.CreateCriteria(typeof(User)).Add( ex ).List();

2。取得用户名(Username)为billy, 密码(Password)为123456的用户对象

Expression ex = Expression.And(
Expression.Eq("Username", "billy"),
Expression.Eq("Password", "123456")
); // ( Username='billy' and Password='123456' )
IList users = session.CreateCriteria(type(User)).Add(ex).List();

3. 取得数据中第20-40的用户对象。

ICriteria c = session.CreateCriteria(typeof(User));
IList users = c.SetFirstResult(20).SetMaxResults(20).List();

对于SQLSERVER,数据定位采用的是IDataReader前滚至firstResult处,然后取maxResults条记录.

4. 取得按注册日期(Regdate)降序排序后的用户对象.

ICriteria c = session.CreateCriteria(typeof(User));
IList users = c.AddOrder( Order.Desc("Regdate") ).List();

使用Criteria加载数据的不足:

1. 当使用SetFirstResult和SetMaxResults限制返回的对象数时,无法得知对象的总数;
2. 当前版本不支持关联查询(hibernate好像可以);

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

NHibernate查询之HQL&Criteria

一、什么是HQL(NHibernate Query Language)查询语言 Ø    定义:NHibernate查询语言(HQL,NHibernate Query Language)是N...

使用hibernate的criteria分页查询后得到数组对象

前几日使用了hibernate的级联查询,

NHibernate使用入门(六)

预加载、延迟加载EagerLoading.cs预加载类: public class EagerLoading { ISessionFactory sessionFactory...
  • WuLex
  • WuLex
  • 2016-09-01 23:57
  • 322

NHibernate使用入门(三)

全文检索–查询数据NHibernate.config配置文件 <property name
  • WuLex
  • WuLex
  • 2016-08-31 14:39
  • 489

NHibernate使用入门(一)

项目结构如图:Product.cs模型类 public class Product { public virtual Guid Id { get; set; } ...
  • WuLex
  • WuLex
  • 2016-08-30 21:33
  • 554

NHibernate使用入门(十)

多对一双向映射
  • WuLex
  • WuLex
  • 2016-09-02 14:18
  • 305

NHibernate使用入门(五)

项目结构如图:Model类库如下Customer.cs类和Customer.hbm.xml实体映射文件[Serializable] public class Customer { ...
  • WuLex
  • WuLex
  • 2016-09-01 14:21
  • 688

NHibernate使用入门(十二)

双向一对多关联映
  • WuLex
  • WuLex
  • 2016-09-03 11:19
  • 289

NHibernate使用入门(七)

多对多关联单向映射相关实体类参考前面Category.hbm.xml映射文件 <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default...
  • WuLex
  • WuLex
  • 2016-09-02 11:18
  • 304

NHibernate使用入门(九)

多对一单向映射:多对一的映射关系是在多的一端进行维护的,一对多关系映射则由一端来维护这种关系。Customer.cs类和Customer.hbm.xml实体映射文件 [Serializable] ...
  • WuLex
  • WuLex
  • 2016-09-02 13:53
  • 307
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)