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

PostgreSQL Discussion :

lock sur update


Sujet :

PostgreSQL

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 16
    Points : 16
    Points
    16
    Par défaut lock sur update
    bonjour

    je travaille avec une base postgresql à partir d'une appli en windev (oui, je sais...)
    lorsque je bloque un enregistrement (select...for update), je voudrais que les autres utilisateurs soient prévenus si ils veulent bloquer le même enregistrement que moi.
    si je modifie dans postgresql.conf
    statement_timeout = 1000
    j' ai bien une erreur indiquant que la requète a échoué.
    sauf que j'ai la même erreur lors d'une requète dépassant 1 seconde. Sad
    j'ai reparamétré le statement_timeout à 15000, mais attendre 15 secondes pour se faire dire que le record est bloqué, ça fait un peu long.
    Pour exécuter une requète complexe, 15 secondes, ça peut faire court.
    y a-t-il une autre possibilité ? si oui, laquelle ?

  2. #2
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 16
    Points : 16
    Points
    16
    Par défaut lock sur update
    bonjour,
    je suis très surpris de ne strictement rien trouver concernant ce problème de lock.
    Je suppose que la plupart des utilisateurs de postgresql bloquent des lignes (au moins lors d'un select for update)
    comment empecher les autres utilisateurs de rester bloqués jusqu'à un commit ou rollback ?

    pour ce qui me concerne, je modifie la valeur de statement_timeout juste avant le select (set local statement_timeout = 5000, par ex.)
    ça, ça fonctionne. Je pense qu'il doit y avoir plus propre.

    A moins que ma question ne soit trop triviale ?

  3. #3
    Expert éminent
    Avatar de GrandFather
    Inscrit en
    Mai 2004
    Messages
    4 587
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Mai 2004
    Messages : 4 587
    Points : 7 103
    Points
    7 103
    Par défaut
    Bonjour,

    si tu veux avoir un contrôle plus fin des verrouillages, regarde du côté du côté de la commande SQL LOCK.

    Sinon, tu peux utiliser la vue système pg_locks qui t'informe en temps réel des verrouillages en cours dans la base (voir http://www.postgresql.org/docs/7.3/s...ing-locks.html ); un client peut consulter cette vue, vérifier si la table est libre, et le cas échéant informer l'utilisateur sans délai.
    FAQ XML
    ------------
    « Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
    Giacomo Leopardi

  4. #4
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 16
    Points : 16
    Points
    16
    Par défaut
    Ok merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 24/09/2010, 19h01
  2. pb lock sur update ou delete
    Par cyberyan dans le forum Oracle
    Réponses: 1
    Dernier message: 13/12/2006, 08h20
  3. [VB.NET] Pb sur update à partir champs Textbox
    Par patdez dans le forum ASP.NET
    Réponses: 5
    Dernier message: 28/06/2006, 09h28
  4. Faire un Lock sur une table pendant l'exec d'un DTS
    Par Pete dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 14/03/2005, 14h17
  5. Evenement sur UPDATE, INSERT, DELETE
    Par papouAlain dans le forum Langage SQL
    Réponses: 6
    Dernier message: 23/12/2004, 14h58

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