sql >> Base de Datos >  >> RDS >> Sqlserver

Nhibernate establece el período de tiempo de espera de consulta para comandos y bloqueo pesimista

Para lograr el bloqueo pesimista, debe obtener los detalles del objeto mediante ICritiera.
El código alterado se proporciona a continuación:

using (var session = sessionFactory.OpenSession()) {
    using (var sqlTrans = session.BeginTransaction()) {
        ICriteria criteria = session.CreateCriteria<Foo>();
        criteria.Add(Restrictions.Eq(fieldOnWhichYouWishToGetTheLock, fieldValue));
        criteria.SetLockMode(LockMode.Upgrade);
        criteria.SetTimeout(5);
        Foo fooObject = (Foo)criteria.List<Foo>();
        //Make the changes to foo object and save as usual.
    }
}