Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Nhibernate définissant le délai d'expiration de la requête pour les commandes et le verrouillage pessimiste

Pour obtenir un verrouillage pessimiste, vous devez obtenir les détails de l'objet à l'aide d'ICritiera.
Le code modifié est donné ci-dessous :

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.
    }
}