码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2016-07-23 22:47:15      阅读:267      评论:0      收藏:0      [点我收藏+]

标签:

摘要

NHibernate从3.0开始支持Linq查询。写Linq to NHibernate查询就跟写.net linq代码一样,非常灵活,可以很容易实现复杂的查询。这篇文章使用Linq to NHibernate重写之前所有的查询。

本篇文章的代码可以到NHibernate查询下载

1、创建IQueryable对象,返回所有Customer对象信息

1         public IList<Customer> QueryAllLinq()
2         {
3             return Session.Query<Customer>().ToList();
4         }
  • 要在代码中添加对NHibernate.Linq的引用
  • IQueryable对象是延迟加载的
  • ToList方法表示立即执行,得到IList<Customer>集合

2、创建别名

1         public IList<Customer> QueryAllLinq()
2         {
3             return (from c in Session.Query<Customer>().ToList() select c).ToList();
4         }

3、指定对象返回数组

1         public IList<int> SelectIdLinq()
2         {
3             var query = Session.Query<Customer>().Select(c => c.Id).Distinct().ToList();
4             return query.ToList();
5         }

Distinct方法返回无重复项目的序列。

4、添加查询条件

 1         public IList<Customer> GetCustomerByNameLinq(string firstName, string lastName)
 2         {
 3             return Session.Query<Customer>().Where(c => c.FirstName == firstName && c.LastName == lastName).ToList();
 4         }
 5 
 6         public IList<Customer> GetCustomersStartWithLinq()
 7         {
 8             var query = from c in Session.Query<Customer>() where c.FirstName.StartsWith("J") select c;
 9             return query.ToList();
10         }

5、order by

1         public IList<Customer> GetCustomersOrderByLinq()
2         {
3             var query = from c in Session.Query<Customer>() orderby c.FirstName ascending select c;
4             return query.ToList();
5         }

6、关联查询

 1         public IList<OrderCount> SelectOrderCountLinq()
 2         {
 3             var query = Session.Query<Customer>().Select(g => new OrderCount { CustomerId = g.Id, Count = g.Orders.Count() });
 4             return query.ToList();
 5         }
 6 
 7         public IList<Customer> GetCustomersOrderCountGreaterThanLinq()
 8         {
 9             var query = Session.Query<Customer>().Where(c => c.Orders.Count > 2);
10             return query.ToList();
11         }
12 
13         public IList<Customer> GetCustomersOrderDateGreatThanLinq(DateTime orderDate)
14         {
15             var query = Session.Query<Customer>().Where(c => c.Orders.Any(o => o.Ordered > orderDate));
16             return query.ToList();
17         }

因为.net方法不能返回匿名类对象以及含有匿名类对象的对象,因此添加OrderCount类,SelectOrderCountLinq方法返回IList<OrderCount>对象。

1     public class OrderCount
2     {
3         public int CustomerId { get; set; }
4         public int Count { get; set; }
5     }

 

结语

Linq to NHibernate基于.net Linq,非常灵活。.net Linq提供的所有集合操作,Linq to NHibernate也都提供了。使用它可以完成大部分NHibernate查询。下一篇文章介绍NHibernate 3.2的Query Over查询。

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

标签:

原文地址:http://www.cnblogs.com/uncle_danny/p/5676263.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!