В этой главе мы рассмотрим, как работает кэширование в приложениях 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 знает, что нет необходимости запускать другой запрос, чтобы снова получить тот же объект сотрудника. ,