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

ADO.NET Discussion :

StackOverflowException dans l'évenement "ColumnChanged"


Sujet :

ADO.NET

  1. #1
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut StackOverflowException dans l'évenement "ColumnChanged"
    Bonjour à tous,
    J'ai un problème que je n'arrive pas à résoudre.
    J'ai une procédure que j’appelle depuis l’évènement ColumnChanged d'une DataTable. Cette procédure est destinée à contrôler les données de chaque DataRow et selon une logique métier elle peut retourner des modifications de données à cette même DataRow.
    Lors de l'affectation de nouvelles valeurs à la Datarow, cela à pour conséquence de lever de nouveaux évènements ColumnChanged et entraîne donc des appels récursifs qui finissent par une exception StackOverFlow.

    Je précise que l'évenement ColumnChanged me permet de récupérer plein de choses concernant la modif de la DataRow (e.columnName, e.ProposedValue....etc).

    Ça me rendrais vraiment service si vous pouvez m'aider à régler le problème.

  2. #2
    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 : 43
    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 753
    Points
    39 753
    Par défaut
    Tu pourrais te désabonner de l'évènement ColumnChanged quand tu commences à le traiter, et te réabonner à la fin...

  3. #3
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut
    Merci de m'avoir répondu Tomlev. C'est en effet ce que je vais faire mais je pensais que peut-être j'avais loupé quelques choses comme ne pas utiliser le bon évènement ou autres. Je reste quand même un peu surpris de l'absence d’évènement au niveau du DataTable qui pourrais permettre à la fois l'interception des changements et la modification des données sans que cela se morde la queue....

  4. #4
    Membre averti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2012
    Messages
    640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Bâtiment

    Informations forums :
    Inscription : Mars 2012
    Messages : 640
    Points : 372
    Points
    372
    Par défaut
    Je passe en résolu. je désactive/réactive l'evenement à la demande pour régler le probléme.

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

Discussions similaires

  1. Modification d'un texte dans une fenetre "d'erreur"
    Par PAUL87 dans le forum Access
    Réponses: 8
    Dernier message: 21/10/2005, 13h12

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