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 :

Problème: Accès concurrent a la base de données avec les Thread


Sujet :

C#

  1. #1
    Membre régulier
    Inscrit en
    Juin 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 106
    Points : 85
    Points
    85
    Par défaut Problème: Accès concurrent a la base de données avec les Thread
    Salut a tours les pro du c#

    J'ai besoin de votre conseille a propos de l’accès concourent a la base de données par mon application.

    Bref, j'ai une application qui interagie avec une base, et qui contient plusieurs Thread (en ce moment il y'a 4, 2 qui interagie avec un appareille et les deux autre avec la base de donnée, 1 qui démarre avec l'application et l'autre lors de l'ouverture d'un formulaire)

    Je m'attendais d'avoir un problème d'accès concourent es ce que c'est vrai ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
    ExecuteReader requires an open and available Connection. The connection's current state is connecting.
     
    System.InvalidOperationException was unhandled
      Message=ExecuteReader requires an open and available Connection. The connection's current state is connecting.
      Source=System.Data
      StackTrace:
           at System.Data.SqlClient.SqlConnection.GetOpenConnection(String method)
           at System.Data.SqlClient.SqlConnection.ValidateConnectionForExecute(String method, SqlCommand command)
           at System.Data.SqlClient.SqlCommand.ValidateCommand(String method, Boolean async)
           at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)
           at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)
           at System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)
           at System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)
           at System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)
           at System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
           at System.Data.Common.DbDataAdapter.Fill(DataTable[] dataTables, Int32 startRecord, Int32 maxRecords, IDbCommand command, CommandBehavior behavior)
           at System.Data.Common.DbDataAdapter.Fill(DataTable dataTable)
           at HPR.BDDataSetTableAdapters.R_LATableAdapter.GetData() in D:\HPR\HPR\HPR\HPR\BDHPDataSet.Designer.cs:line 16688
           at HPR.FRM_GR.Refrech_DGV_LA() in D:\HPR\HPR\HPR\HPR\FRM_GR.cs:line 73
           at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
           at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean ignoreSyncCtx)
           at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
           at System.Threading.ThreadHelper.ThreadStart()
      InnerException:

    Pour votre info j'ai utilisé un MUTEX pour géré les accès a l'appareille, et je me demande si je doit aussi le faire a la base de donnée si oui alors svp y'a pas un moyen plus rapide que le mètre avant chaque "insert" ou un "select" sachant que j'utlise les "TableAdapter".


    Bref une dernière question si c'est possible, le meilleur moyen d'afficher l'état d'une table en temps réel sur un "DataGridView", pour le moment j'ai mit un thread qui actualiser l'affichage.

    Merci de votre attention et svp n'importe quel indication est la bienvenue n'hésitez pas svp.

  2. #2
    Membre expérimenté

    Homme Profil pro
    Responsable des études
    Inscrit en
    Mars 2009
    Messages
    553
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2009
    Messages : 553
    Points : 1 672
    Points
    1 672
    Par défaut
    Hello,

    D'après le message d'erreur, j'ai surtout l'impression que tu n'es pas connecté à la base de données.

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Ca dépend de la DB utilisée... avec SQL Server, tu peux l'utiliser depuis plusieurs threads, par contre il faut que chaque thread utilise son propre objet SqlConnection

  4. #4
    Membre régulier
    Inscrit en
    Juin 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 106
    Points : 85
    Points
    85
    Par défaut
    Citation Envoyé par nnovic Voir le message
    Hello,

    D'après le message d'erreur, j'ai surtout l'impression que tu n'es pas connecté à la base de données.
    Merci nnovic pour votre réponse.
    Oui effectivement, il ne peux pas ce connecté parce que un autre Thread est connecté.

    Citation Envoyé par tomlev Voir le message
    Ca dépend de la DB utilisée... avec SQL Server, tu peux l'utiliser depuis plusieurs threads, par contre il faut que chaque thread utilise son propre objet SqlConnection
    Merci tomlev pour votre réponce.
    OK je ne vais pas utiliser le même SQLConnection.

  5. #5
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    avec SQL Server, tu peux l'utiliser depuis plusieurs threads, par contre il faut que chaque thread utilise son propre objet SqlConnection
    C'est effectivement une solution, mais elle n'est pas forcément la mieux adaptée pour répondre au problème suivant :
    le meilleur moyen d'afficher l'état d'une table en temps réel sur un "DataGridView",
    On peut :

    • binder le DataGridViiew à la DataTable (le DataGridView se met à jour automatiquement dès que la DataTable est modifiée),
    • gérer dans le thread principal DataAdapter, DataTable et DataGridView.
    • partager la DataTable entre lesThreads,
    • éviter les accès concurents à la modification de la datable avec l'instruction "lock(MyDataTable)"
    • écrire la procedure de validation de la dataTable contenant le "DataAdapter.Update()" dans une fonction du thread principal,
    • appeler cette fonction depuis les threads secondaires avec un "Invoke".
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

  6. #6
    Membre régulier
    Inscrit en
    Juin 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 106
    Points : 85
    Points
    85
    Par défaut
    Citation Envoyé par Graffito Voir le message
    C'est effectivement une solution, mais elle n'est pas forcément la mieux adaptée pour répondre au problème suivant :
    On peut :

    • binder le DataGridViiew à la DataTable (le DataGridView se met à jour automatiquement dès que la DataTable est modifiée),
    • gérer dans le thread principal DataAdapter, DataTable et DataGridView.
    • partager la DataTable entre lesThreads,
    • éviter les accès concurents à la modification de la datable avec l'instruction "lock(MyDataTable)"
    • écrire la procedure de validation de la dataTable contenant le "DataAdapter.Update()" dans une fonction du thread principal,
    • appeler cette fonction depuis les threads secondaires avec un "Invoke".

    Merciiiiiiii Graffito, votre réponse est vraiment la cerise sur le gâteau Si ce n'est pas trop demander, comment on procede pour que le DataTable se met ajour dés qu'il ya un changement dans table au niveau de la base de donnée ?

    Es ce que je doit utiliser un TRIGGER ? (after insert,update,delete)

    PS: Je pense que la raison de ma question c'est que: Je n'est pas bien compri ce que l'étape 5 demande


    Citation Envoyé par Graffito Voir le message
    ....
    5[*] "écrire la procedure de validation de la dataTable contenant le "DataAdapter.Update()" dans une fonction du thread principal."
    ...
    Merci Encore de votre attention et désolé du dérangement.

  7. #7
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    comment on procede pour que le DataTable se met ajour dés qu'il ya un changement dans table au niveau de la base de donnée
    Malheureusement on n'a pas d'indication des changements dans base de donnée. Pour "rafraîchir" le DataTable , on peut seulement réexécuter le DataAdapter.Fill(), ce qui se traduit par une commande SQL SELECT. Mais, ce n'est utile que pour importer des modifications effectuées par un autre utilisateur.

    Le principe général est :

    • On charge la DataTable ou un extrait via le DataAdapter [fonction Fill()],
    • On modifie la DataTable (le Datagridview se met à jour sans qu'on ait à coder quoique soit),
    • On transfère via le DataAdapter [fonction Update()] une ou des modifications à la base de donnée : c'est "l'étape 5".
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

  8. #8
    Membre régulier
    Inscrit en
    Juin 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 106
    Points : 85
    Points
    85
    Par défaut
    Citation Envoyé par Graffito Voir le message
    Malheureusement on n'a pas d'indication des changements dans base de donnée. Pour "rafraîchir" le DataTable , on peut seulement réexécuter le DataAdapter.Fill(), ce qui se traduit par une commande SQL SELECT. Mais, ce n'est utile que pour importer des modifications effectuées par un autre utilisateur.

    Le principe général est :

    • On charge la DataTable ou un extrait via le DataAdapter [fonction Fill()],
    • On modifie la DataTable (le Datagridview se met à jour sans qu'on ait à coder quoique soit),
    • On transfère via le DataAdapter [fonction Update()] une ou des modifications à la base de donnée : c'est "l'étape 5".
    Je vous remercie infiniment pour ton aide précieuse

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

Discussions similaires

  1. Connexion a une base de données avec les interfaces Swing
    Par diengkals dans le forum AWT/Swing
    Réponses: 4
    Dernier message: 09/10/2013, 13h39
  2. Création d'une base de données avec les composants " BDE "
    Par Y013S dans le forum Bases de données
    Réponses: 4
    Dernier message: 22/12/2010, 23h43
  3. Réponses: 0
    Dernier message: 25/05/2010, 15h29
  4. Réponses: 33
    Dernier message: 03/09/2009, 18h27
  5. Problème Update Base de données avec les composants ADO
    Par lingli dans le forum Bases de données
    Réponses: 5
    Dernier message: 20/04/2006, 00h41

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