一起谈.NET技术,NHibernate3.0剖析:Query篇之NHibernate.Linq增强查询

简介:   相关文章:NHibernate3.0剖析:Query篇之NHibernate.Linq标准查询  系列引入  NHibernate3.0剖析系列分别从Configuration篇、Mapping篇、Query篇、Session策略篇、应用篇等方面全面揭示NHibernate3.0新特性和应用及其各种应用程序的集成,基于NHibernte3.0版本。

  相关文章:NHibernate3.0剖析:Query篇之NHibernate.Linq标准查询

  系列引入

  NHibernate3.0剖析系列分别从Configuration篇、Mapping篇、Query篇、Session策略篇、应用篇等方面全面揭示NHibernate3.0新特性和应用及其各种应用程序的集成,基于NHibernte3.0版本。如果你还不熟悉NHibernate,可以快速阅读NHibernate之旅系列文章导航系列入门,如果你已经在用NHibernate了,那么请跟上NHibernate3.0剖析系列吧。

  增强查询概述

  NHibernate.Linq除了提供标准查询运算符外,NHibernate.Linq还专门提供了NHibernate特有的两个增强查询方法,分别是立即抓取(EagerFetching)和查询缓存(QueryCacheable)。

  立即抓取(EagerFetching)

  如果我们不在Mapping文件中对对象关联关系设置Lazy="false",默认是延迟加载的,NHibernate3.0提供了四种扩展方法。分别为Fetch及ThenFetch,FetchMany及ThenFetchMany。在查询时,使用这些方法用于立即加载出关联对象。

Linq-EagerFetchingExtensionMethods  实例分析

  关联关系默认是延迟加载的,例如下面NHibernate.Linq查询查询出所有Customer,其Order集合默认是延迟加载的。

//Code Snippets Copyright http://lyj.cnblogs.com/
var x = session.Query<Customer>().ToList();

  使用Fetch立即加载关联关系,例如立即加载所有Customer对象Order集合。

//Code Snippets Copyright http://lyj.cnblogs.com/
var x = session.Query<Customer>().Fetch(c => c.Orders).ToList();

  使用Fetch对象立即加载多个关联关系,如果一个对象有多种集合,我们可以使用下面方法立即加载多个关联关系。例如Employee对象有Subordinates及Orders集合,使用下面方法立即加载出所有Employee对象的Subordinates和Orders集合。

//Code Snippets Copyright http://lyj.cnblogs.com/
var x = session.Query<Employee>()
    .Fetch(e => e.Subordinates)
    .Fetch(e => e.Orders).ToList();

  使用Fetch及ThenFetch,FetchMany及ThenFetchMany立即加载嵌套关联,例如Customer对象有Order集合,Order集合也有多个OrderLines集合,可以使用下面方法全部立即加载出来。

//Code Snippets Copyright http://lyj.cnblogs.com/
var x = session.Query<Customer>()
    .FetchMany(c => c.Orders)
    .ThenFetchMany(o => o.OrderLines).ToList();

  查询缓存(QueryCacheable)

  NHibernate3.0提供了三种扩展方法对查询缓存(QueryCacheable)的支持。

Linq-CacheableExpressionNode

  • Cacheable用于开启查询缓存。
  • CacheMode用于设置缓存策略。
  • CacheRegion用于设置缓存区域。

  下面NHibernate.Linq查询开启查询缓存,当执行这句查询时,首先从QueryCache里面查询,看看是否存在了,不存在则查询数据库后放入QueryCache,存在则直接从QueryCache中获取。

//Code Snippets Copyright http://lyj.cnblogs.com/
var q = session.Query<Customer>().Cacheable().ToList();

  下面Linq查询开启查询缓存,设置缓存区域和策略。

//Code Snippets Copyright http://lyj.cnblogs.com/
var q = session.Query<Customer>()
    .Cacheable().CacheRegion("Test")
    .CacheMode(CacheMode.Put).ToList();

  实例分析

  IStatistics接口提供QueryExecutionCount、QueryCachePutCount、QueryCacheHitCount三个属性用来统计查询缓存执行数目、Put数目、击中数目。

  注意NHibernate默认不启用查询缓存,我们需要额为配置:

//Code Snippets Copyright http://lyj.cnblogs.com/
cfg.SetProperty(Environment.UseQueryCache, "true");

  例如下面例子:执行两次相同的查询,验证查询执行数目为1,Put数目为1,击中数目为1。

//Code Snippets Copyright http://lyj.cnblogs.com/
[Test]
public void QueryCacheable()
{
    SessionFactory.Statistics.Clear();
    SessionFactoryImplementor.QueryCache.Clear();
    var session = SessionFactory.OpenSession();
    //Execution and Put Query
    var q = session.Query<Customer>().Cacheable().ToList();
    //Get Results from QueryCache
    var q2 = session.Query<Customer>().Cacheable().ToList();
    SessionFactory.Statistics.QueryExecutionCount.Should().Be.EqualTo(1);
    SessionFactory.Statistics.QueryCachePutCount.Should().Be.EqualTo(1);
    SessionFactory.Statistics.QueryCacheHitCount.Should().Be.EqualTo(1);
}

  如果使用NHibernate Profiler监视上面的测试,可以看到其执行了一条语句,第二条直接使用查询缓存。

Linq-QueryCacheableResults  结语

  这篇在NHibernate.Linq标准查询的基础上,介绍了NHibernate特有的两个NHibernate.Linq增强查询立即抓取(EagerFetching)和查询缓存(QueryCacheable)。下篇继续。

  延伸阅读

  MIKE HADLOW:NHibernate Linq Eager Fetching

  Ayende:Eagerly loading entity associations efficiently with NHibernate

  希望本文对你有所帮助。

目录
相关文章
|
22天前
|
人工智能 开发框架 C#
C#/.NET/.NET Core技术前沿周刊 | 第 6 期(2024年9.16-9.22)
C#/.NET/.NET Core技术前沿周刊 | 第 6 期(2024年9.16-9.22)
|
22天前
|
人工智能 开发框架 Cloud Native
C#/.NET/.NET Core技术前沿周刊 | 第 9 期(2024年10.07-10.13)
C#/.NET/.NET Core技术前沿周刊 | 第 9 期(2024年10.07-10.13)
|
22天前
|
数据可视化 NoSQL C#
C#/.NET/.NET Core技术前沿周刊 | 第 8 期(2024年10.01-10.06)
C#/.NET/.NET Core技术前沿周刊 | 第 8 期(2024年10.01-10.06)
|
22天前
|
设计模式 开发框架 C#
C#/.NET/.NET Core技术前沿周刊 | 第 4 期(2024年9.1-9.8)
C#/.NET/.NET Core技术前沿周刊 | 第 4 期(2024年9.1-9.8)
|
2月前
|
人工智能 前端开发 开发工具
解读.NET 技术的开发潜力
本文全面介绍了.NET技术在软件开发领域的核心优势、创新应用及面临的挑战。.NET以其统一的开发平台、强大的工具和跨平台能力,成为企业级应用、Web应用乃至游戏开发的理想选择。然而,在性能优化、容器化及AI集成等方面仍需不断突破。通过积极拥抱开源和社区驱动模式,.NET将持续推动软件开发的进步。
53 1
|
2月前
|
监控 网络协议 API
.NET WebSocket 技术深入解析,你学会了吗?
【9月更文挑战第4天】WebSocket 作为一种全双工协议,凭借低延迟和高性能特点,成为实时应用的首选技术。.NET 框架提供了强大的 WebSocket 支持,使实时通信变得简单。本文介绍 WebSocket 的基本概念、.NET 中的使用方法及编程模型,并探讨其在实时聊天、监控、在线游戏和协同编辑等场景的应用,同时分享最佳实践,帮助开发者构建高效实时应用。
134 12
|
2月前
|
人工智能 前端开发 Devops
.NET技术自发布以来,在软件开发领域发挥了重要作用
【9月更文挑战第12天】.NET技术自发布以来,在软件开发领域发挥了重要作用。本文分为三部分探讨其在现代开发中的应用:首先介绍.NET的核心价值,包括语言多样性、强大的开发工具支持、丰富的类库、跨平台能力和活跃的社区;接着分析其在企业级应用、Web开发、移动应用、云服务及游戏开发中的实际应用;最后讨论.NET面临的挑战与未来趋势,如性能优化、容器化、AI集成及跨平台框架竞争等。通过不断的技术创新和社区驱动,.NET将持续推动软件开发的进步。
37 4
|
2月前
|
人工智能 开发框架 算法
C#/.NET/.NET Core技术前沿周刊 | 第 2 期(2024年8.19-8.25)
C#/.NET/.NET Core技术前沿周刊 | 第 2 期(2024年8.19-8.25)
|
2月前
|
传感器 应用服务中间件 Linux
C#/.NET/.NET Core技术前沿周刊 | 第 3 期(2024年8.26-8.31)
C#/.NET/.NET Core技术前沿周刊 | 第 3 期(2024年8.26-8.31)
|
2月前
|
人工智能 算法 C#
C#/.NET/.NET Core技术前沿周刊 | 第 1 期(2024年8.12-8.18)
C#/.NET/.NET Core技术前沿周刊 | 第 1 期(2024年8.12-8.18)