Учебники

NHibernate — Кэширование

В этой главе мы рассмотрим, как работает кэширование в приложениях NHibernate. Имеет встроенную поддержку кеширования. Это выглядит как простая функция, но на самом деле это одна из самых сложных функций. Начнем с кэша первого уровня.

Кэш первого уровня

Этот механизм кеширования по умолчанию включен в NHibernate, и нам не нужно ничего делать для работы с кешем. Чтобы понять это, давайте рассмотрим простой пример, поскольку вы можете видеть, что у нас есть две записи в нашей базе данных.

Кэш первого уровня

Теперь в этом примере мы извлечем учащегося, чей ID равен 1, и дважды будем использовать один и тот же запрос сеанса, как показано в следующем коде.

using HibernatingRhinos.Profiler.Appender.NHibernate; 
using NHibernate.Cache; 
using NHibernate.Cfg; 
using NHibernate.Dialect;
using NHibernate.Driver; 
using NHibernate.Linq; 

using System; 
using System.Linq; 
using System.Reflection;
namespace NHibernateDemoApp { 
   
   class Program { 
      static void Main(string[] args) {
		
         NHibernateProfiler.Initialize(); 
         var cfg = new Configuration(); 
			
         String Data Source = asia13797\\sqlexpress;
         String Initial Catalog = NHibernateDemoDB;
         String Integrated Security = True;
         String Connect Timeout = 15;
         String Encrypt = False;
         String TrustServerCertificate = False;
         String ApplicationIntent = ReadWrite;
         String MultiSubnetFailover = False;
         
         cfg.DataBaseIntegration(x = > { x.ConnectionString = "Data Source + 
            Initial Catalog + Integrated Security + Connect Timeout + Encrypt +
            TrustServerCertificate + ApplicationIntent + MultiSubnetFailover";
				
            x.Driver<SqlClientDriver>(); 
            x.Dialect<MsSql2008Dialect>(); 
            x.LogSqlInConsole = true; 
            x.BatchSize = 10; 
         }); 
         
         //cfg.Configure(); 
         
         cfg.Cache(c => { 
            c.UseMinimalPuts = true; 
            c.UseQueryCache = true; 
         }); 
			
         cfg.SessionFactory().Caching .Through<HashtableCacheProvider>()
            .WithDefaultExpiration(1440); 
         cfg.AddAssembly(Assembly.GetExecutingAssembly()); 
         var sefact = cfg.BuildSessionFactory(); 
         
         using (var session = sefact.OpenSession()){ 
			
            using (var tx = session.BeginTransaction()) { 
               var studentUsingTheFirstQuery = session.Get<Student>(1);
               var studentUsingTheSecondQuery = session.Get<Student>(1); 
            } 
            
            Console.ReadLine(); 
         } 
      } 
   } 
}

Теперь давайте запустим это приложение и увидим результат в NHibernate Profiler.

Запустите приложение

Вы будете удивлены, увидев, что NHibernate запускает только один запрос. Вот как NHibernate использует кэш первого уровня. Когда выполняется первый запрос, NHibernate кэширует Student с ID = 1 в своем кеше первого уровня.

Итак, когда второй запрос выполняется, тогда NHibernate сначала ищет сущность кеша первого уровня с идентификатором ID = 1, если он находит эту сущность, то NHibernate знает, что нет необходимости запускать другой запрос, чтобы снова получить тот же объект сотрудника. ,