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

C# Discussion :

Gestion de concurrence sur postgres/c#


Sujet :

C#

  1. #1
    Invité
    Invité(e)
    Par défaut Gestion de concurrence sur postgres/c#
    Bonjour,

    J'utilise c# et postgresql, donc je ne sais pas si je suis dans la bonne section, mais bon.

    En fait, j'utilise n applications (n>1) pour accéder à une base de donnée. Les applications récupèrent une ID qui est PRIMARYKEY (la valeur MAX()), incrémente l'ID (ID + 1) et écrit cette nouvelle valeur dans la base.

    Le probleme est que, a un certain moment, les applications recuperent la meme valeur MAX(ID) et tentent d'ecrire la meme valeur sur la base et qui provoque bien evidement une erreur.

    Ce que je veux faire est d'eviter cette erreur lors de la concurrence.

    Merci bcp.

  2. #2
    Membre Expert

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    2 067
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 2 067
    Par défaut
    Pourquoi ne pas utiliser un id auto incrémenté plutôt, tu as le type serial pour ça.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour, desolé de la reponse tardive.

    Mais le probleme est au niveau de c#, l'application tente alors d'ecrire un ID deja presente et cela provoquera certainement une erreur.

  4. #4
    Membre expérimenté
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2012
    Messages
    162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Luxembourg

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2012
    Messages : 162
    Par défaut
    Bonjour,

    A moins d'avoir un serveur d'application commun à tous les clients qui est chargé de fournir l'incrémentation de l'ID, je pense que la solution se trouve au niveau de la base de donné PostGreSQL qui doit être l'élément centrale dans votre cas.
    Je vous propose de lire la documentation postgresql.
    Cordialement

  5. #5
    Invité
    Invité(e)
    Par défaut
    Ce que je comprends dans cette documentation, c'est que le verrous marche au niveau de la base.
    Pour éviter de tout restructurer et de créer une nouvelle application serveur, serait t-il possible de faire en même temps : récupération de l'ID a utiliser et écriture (dans une même requête bien sur )

  6. #6
    Membre émérite
    Avatar de neilbgr
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2004
    Messages
    651
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 651
    Par défaut
    Il y a aussi cette référence : http://sqlpro.developpez.com/cours/clefs/
    qui explique ce qu'il faut éviter de faire, et plusieurs solutions pour arriver à ce que l'on veut.

Discussions similaires

  1. [MySQL 5] Gestion des accès concurrents sur un moteur InnoDB
    Par Kaldyris dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/06/2011, 16h45
  2. Application de gestion des sms sur PC
    Par andyvo dans le forum Langage
    Réponses: 9
    Dernier message: 20/10/2005, 23h49
  3. probleme sur postgres
    Par bananaloozeur dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 10/10/2005, 13h42
  4. [Gestion mémoire] SetLength sur TDoubleDynArray
    Par MD Software dans le forum Langage
    Réponses: 14
    Dernier message: 24/04/2005, 21h11
  5. Pb d'accès à distance sur Postgre pour windows
    Par Guitch dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 28/09/2004, 19h13

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