Кэш сеанса Nhibernate v4.0.30319 и результаты запросовC#

Место общения программистов C#
Ответить
Anonymous
 Кэш сеанса Nhibernate v4.0.30319 и результаты запросов

Сообщение Anonymous »

Мы используем Nhibernate v4.0.30319 и Flushmode.Commit. Давайте рассмотрим пример таблицы сотрудников со столбцом IsActive в БД.
В одной из транзакций мы получаем empId сотрудника =100

Код: Выделить всё

var employee = session.Get(100);

employee.IsActive = false;
Он еще не зафиксирован и даже не удален.
Мы немедленно запускаем запрос, чтобы получить всех активных сотрудников.

Код: Выделить всё

var activeEmployees = session.CreateCriteria()
.Add(Restrictions.Eq("IsActive", true))
.List();
Теперь в результате activeEmployees я все еще получаю сведения о сотруднике empId-100, но со значением IsActive как ложным.
Я не могу понять, почему такое непоследовательное поведение. Если запрос выполняется в БД, он должен возвращать empId-100 со значением IsActive «True». В противном случае, если он выполняется в кеше первого уровня, он не должен включать empId-100 в результат запроса. Здесь он возвращает EmpId-100 с IsActive false.
Почему он так себя ведет? Я просмотрел некоторые статьи и сведения о конфигурациях, но не могу понять, что происходит с этим поведением.
Спасибо,
Нагасри.

Подробнее здесь: https://stackoverflow.com/questions/793 ... ry-results
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»