IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement SQL Server Discussion :

Lock - verouiller un enregistrement


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    202
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 202
    Par défaut Lock - verouiller un enregistrement
    Bonjour,

    Je souhaiterais verouiller un enregistrement dans une table afin que deux utilisateurs ne puissent pas faire de modifications concurentes.

    Je m'explique en détail.

    Imaginez une application windows forms avec un listing de clients.

    Lorsqu'un utilisateur clique sur un client, sa fiche s'affiche. A ce moment la, même si rien n'a été modifié sur la fiche, je souhaiterais bloquer les autres utilisateurs afin qu'ils ne puissent pas ouvrir cette même fiche en même temps.

    Si le pc du premier utilisateur plante, je souhaiterais que le verrou soit automatiquement verouillé.

    En mysql, il existe un truc qui s'appelle get_lock() et qui aurait pu répondre à mon problème ici.
    Donc si quelqu'un connait un mécanisme équivalent à get_lock, je suis preneur !

    D'avance merci pour vos réponses

    A+

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 999
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 999
    Billets dans le blog
    6
    Par défaut
    Cette façon de faire est catastrophique et n'avait de seul intérêt que du temps des fichiers plats du style COBOL !!!
    Nous en sommes aux bases de données en client/serveur qui verrouillent automatiquement en optimiste le temps de traitements.
    Faire ce que vous voulez c'est revenir 30 ans en arrière sur la conception des SI.

    Non seulement cela est catastrophique au plan des performances (ne prévoyez pas plus d'une dizaine d'utilisateur) mais n'a strictement aucun intérêt à quelque niveau que ce soit.

    Essayez de me trouver un seul argument positif à cette façon de faire....
    Je me pose d'ailleurs la question de ce que vous avez appris sur le plan scolaire en matière d'informatique ?

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    202
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 202
    Par défaut
    Je me suis sans doute mal exprimé en voulant parler de lock.

    Au final, ce que je veux, c'est INTERDIRE l'ouverture d'une fiche client si un autre utilisateur l'a déjà ouverte.
    Je me moque du fait que ça fait 70's. Les utilisateurs finaux sont un peu des boeufs et je préfère leur bloquer un accès préventivement, plutot que d'expliquer dans un beau message d'erreur que leurs modifs sont concurentes avec d'autres lorsqu'ils vont valider un truc sur la fiche client.

    Je connais le principe des transactions, niveaux d'isolation et compagnie mais je veux même pas rentrer dans ce débat la.

    Alors certes, je pourrais mettre un flag dans un champ de la table client qui serait positionné à true à l'ouverture puis remis à false à la fermeture mais c'est un peu dangereux en cas de plantage.

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 999
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 999
    Billets dans le blog
    6
    Par défaut
    Quelque soit de façon de faire elle sera dangereuse. Comme c'est du fonctionnel, si vous persistez dans ce genre d'horreur alors faites le de manière fonctionnelle en utilisant justement une colonne (et non un champs, cela n'existe pas dans les SGBDR) pour ce faire.

    Mélanger du fonctionnel et du technique (verrous interne) est à coup sûr le meilleur moyen de faire les pires conneries !

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Membre expérimenté
    Inscrit en
    Février 2009
    Messages
    224
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 224
    Par défaut
    Bonjour,
    Est ce que vous travaillez avec des recordset(.net)? Si oui avez vous essayé les différents modes d'ouverture des recordset tel qu'exppliqué ici.

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    202
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 202
    Par défaut
    Concrètement, vous préconisez quoi si on veut faire une belle application dans les règles de l'art ?

    Je laisse 4 utilisateurs ouvrir une même fiche client et j'avertit du problème lorsqu'ils valident leurs modifications ?

    Il y a effectivement des outils tout fait pour ça (linq to sql gère cela par exemple) mais moi perso j'ai un doute sur le fait que ce soit une bonne chose pour les utilisateurs. (J'ai besoin de votre avis la dessus.)

    Merci

  7. #7
    Membre chevronné Avatar de agemis31
    Profil pro
    DBA
    Inscrit en
    Octobre 2007
    Messages
    399
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : DBA

    Informations forums :
    Inscription : Octobre 2007
    Messages : 399
    Par défaut Pessimiste ?
    Bonjour,

    Ah le vieux débat locks pessismistes vs lock optimistes

    Vous avez l'air d'avoir déjà choisi, il n'empêche que ce débat a été tranché depuis longtemps: pas de lock pessimiste.

    Comme SQLPro l'a dit, ça remonte au temp des BDD fichiers, mais c'est surtout une question de probabilité et de loi de l'emmerdement maximum, pour vous, mais aussi pour vos utilisateurs.

    Quelle est la probabilité pour que cela arrive ?

    Si vous voulez gérer le verrouillage de façon pessimiste, vous allez à mon avis, au devant de nombreux problèmes.

    Les utilisateurs finaux sont un peu des bœufs
    Donc il vont rentrer en modification sur une fiche et la verrouiller pour rien...
    Donc vous allez devoir gérer un timeout...
    Donc les utilisateurs ne seront pas contents...
    Si vous avez beaucoup d'utilisateurs, l'application sera lente, ça ne leur fera sans doute pas plaisir non plus...

    C'est un peu le même débat que sur les conflits de mises à jour.
    Certains font tout pour les éviter un édictant une règle simpliste du genre le premier/dernier gagne.
    En général, ça ne marche pas trop bien.

    @+

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    174
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 174
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    Cette façon de faire est catastrophique et n'avait de seul intérêt que du temps des fichiers plats du style COBOL !!!
    Nous en sommes aux bases de données en client/serveur qui verrouillent automatiquement en optimiste le temps de traitements.
    Faire ce que vous voulez c'est revenir 30 ans en arrière sur la conception des SI.

    Non seulement cela est catastrophique au plan des performances (ne prévoyez pas plus d'une dizaine d'utilisateur) mais n'a strictement aucun intérêt à quelque niveau que ce soit.

    Essayez de me trouver un seul argument positif à cette façon de faire....
    Je me pose d'ailleurs la question de ce que vous avez appris sur le plan scolaire en matière d'informatique ?

    A +
    dire tout ceci sans propose d'alternative bref

  9. #9
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    La seule alternative c'est de confier cela à SQL Server, qui sait très bien le faire tout seul.
    Rappelons que SQL est un langage déclaratif, et qu'en dehors de la recherche de performances, vous ne devez pas vous préoccuper de la façon dont le moteur de base de données gère le verrouillage, ou de la façon dont il accède aux données.

    @++

Discussions similaires

  1. Verouiller un enregistrement avec linq to sql
    Par boby62423 dans le forum Linq
    Réponses: 10
    Dernier message: 29/04/2009, 13h34
  2. Verouiller un enregistrement
    Par MisterDjoe dans le forum IHM
    Réponses: 4
    Dernier message: 18/04/2008, 18h56
  3. Visualisation d'un enregistrement verouillé
    Par oracliste dans le forum Oracle
    Réponses: 1
    Dernier message: 29/11/2005, 15h28
  4. Temps de lock des enregistrement
    Par allex2108 dans le forum Oracle
    Réponses: 5
    Dernier message: 30/09/2005, 13h37
  5. ADO et le lock d'enregistrement
    Par Emmanuel Lecoester dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 27/09/2005, 12h17

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo