Try Playground
Show / Hide Table of Contents

Query NHibernate Cache

NHibernate also provides a feature of query caching. By enabling query caching, queries made by NHibernate to the database, along with query result sets are cached in NHibernate Cache. Query caching makes use of Second-level Cache to store queries, so that whenever the same query executes again, it can be fetched from the cache.

Any object retrieved as a result of query is cached to its respective regions in NHibernate cache, therefore objects must be marked as cacheable for efficient use of query caching. However, the query and primary keys of the result set are stored in a default query region named NHibernate.Cache.StandardQueryCache.

Note

Not every query's results remain the same for a period of time. Therefore, query caching should only be used with queries whose results are likely to be changed less frequently.

Enabling Query Caching in NHibernate Cache

To enable query caching, add the following property in the NHibernate configuration section's session-factory tag:

<property name="cache.use_query_cache">true</property>

Enabling query cache does not cache each query by default. Instead, queries that need to be cached are set cacheable in code. To set a query cacheable, call SetCacheable(true) function of query while creating query, e.g.,

IQuery qry = session.CreateQuery("from Customer c").SetCacheable(true);

NCache now provides support for asynchronous tasks for add, update, and remove with NHibernate as Second-level Cache.

Using Async Operations with NHibernate Cache

The examples below show the usage of asynchronous operations with NCache as NHibernate Second-level Cache.

  • ListAsync performs the retrieval of data from the database and caches the result in NCache asynchronously.
customers = qry.ListAsync().Result;
  • FlushAsync synchronizes the underlying persistent store with the state held in memory asynchronously.
session.Save(customers);
session.FlushAsync();
  • EvictAsync removes the customer object asynchronously.
ISessionFactory factory;

// Removes a single customer with the provided attribute asynchronously
factory.EvictAsync(typeof(Customer), CustomerID);

// OR

// Removes all customers asynchronously
factory.EvictAsync(typeof(Customer));

Using Sync Operations with NHibernate

The examples below show the usage of synchronous operations with NCache as NHibernate Second-level Cache.

  • List performs the retrieval of data from the database and caches the result in NCache synchronously.
customers = qry.List().Result;
  • Flush synchronizes the underlying persistent store with the state held in memory.
session.Save(customers);
session.Flush();
  • Evict removes the customer object synchronously.
ISessionFactory factory;

// Removes a single customer with the provided attribute synchronously
factory.Evict(typeof(Customer), CustomerID);

// OR

// Removes all customers synchronously
factory.Evict(typeof(Customer));

See Also

Using NCache as NHibernate Second-level Cache
Configuring Database Synchronization with NHibernate
Entity Framework Cache Provider

In This Article
  • Enabling Query Caching in NHibernate Cache
  • Using Async Operations with NHibernate Cache
  • Using Sync Operations with NHibernate
  • See Also

Contact Us

PHONE

+1 (214) 764-6933   (US)

+44 20 7993 8327   (UK)

 
EMAIL

sales@alachisoft.com

support@alachisoft.com

NCache
  • NCache Enterprise
  • NCache Professional
  • Edition Comparison
  • NCache Architecture
  • Benchmarks
Download
Pricing
Try Playground

Deployments
  • Cloud (SaaS & Software)
  • On-Premises
  • Kubernetes
  • Docker
Technical Use Cases
  • ASP.NET Sessions
  • ASP.NET Core Sessions
  • Pub/Sub Messaging
  • Real-Time ASP.NET SignalR
  • Internet of Things (IoT)
  • NoSQL Database
  • Stream Processing
  • Microservices
Resources
  • Magazine Articles
  • Third-Party Articles
  • Articles
  • Videos
  • Whitepapers
  • Shows
  • Talks
  • Blogs
  • Docs
Customer Case Studies
  • Testimonials
  • Customers
Support
  • Schedule a Demo
  • Forum (Google Groups)
  • Tips
Company
  • Leadership
  • Partners
  • News
  • Events
  • Careers
Contact Us

  • EnglishChinese (Simplified)FrenchGermanItalianJapaneseKoreanPortugueseSpanish

  • Contact Us
  •  
  • Sitemap
  •  
  • Terms of Use
  •  
  • Privacy Policy
© Copyright Alachisoft 2002 - 2025. All rights reserved. NCache is a registered trademark of Diyatech Corp.
Back to top