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

VB.NET Discussion :

Erreur sur un chargement de datatable


Sujet :

VB.NET

  1. #1
    Membre actif
    Inscrit en
    Juillet 2013
    Messages
    772
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 772
    Points : 275
    Points
    275
    Par défaut Erreur sur un chargement de datatable
    Bonjour,

    Dans mon Form.Load, j'initialise mes datatables.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.montableAdapter.Fill(Me.MonDataSetTypé.MaDataTable)
    J'en ai ainsi une dizaine à charger de cette manière.

    J'ai remarqué, que la première de la liste provoque une erreur :

    {"Impossible d'activer les contraintes. Une ou plusieurs lignes contiennent des valeurs qui violent les contraintes de type non null, unique ou de clé externe."}
    Si je l'entoure par un Try/Catch, avec rien dans le Catch, et la suite dans un Finally, je peux laisser l'appli continuer comme si de rien n'était. Actuellement mon code ressemble donc à cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Try 
    Me.montableAdapter1.Fill(Me.MonDataSetTypé.MaDataTable1)
    Catch
    Finally
    Me.montableAdapter2.Fill(Me.MonDataSetTypé.MaDataTable2)
    Me.montableAdapter3.Fill(Me.MonDataSetTypé.MaDataTable3)
    ...
    Me.montableAdapterN.Fill(Me.MonDataSetTypé.MaDataTableN)
    End Try
    Vous admettrez que ce n'est pas très élégant.
    J'ai vérifié que l'erreur ne se produit pas sur toutes les lignes. J'en ai en fait 2 qui provoquent cette erreur. Par exemple MaDataTable1 et MaDataTable 3

    Mais si j'écris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Try 
    Me.montableAdapter1.Fill(Me.MonDataSetTypé.MaDataTable1)
    Catch
    Finally
    Me.montableAdapter2.Fill(Me.MonDataSetTypé.MaDataTable2)
    Me.montableAdapter3.Fill(Me.MonDataSetTypé.MaDataTable3)
    L'erreur sur MaDataTable1 est bien catchée et aucune erreur ne se déclenche sur MaDataTable3.

    Idem si j'écris :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Try 
    Me.montableAdapter3.Fill(Me.MonDataSetTypé.MaDataTable3)
    Catch
    Finally
    Me.montableAdapter2.Fill(Me.MonDataSetTypé.MaDataTable2)
    Me.montableAdapter1.Fill(Me.MonDataSetTypé.MaDataTable1)
    L'erreur sur MaDataTable3 est bien catchée et aucune erreur ne se déclenche sur MaDataTable1.

    Cela ne me semble pas très logique. Si j'avais vraiment un pb de SQL dans ma requête sous-jacente, l'erreur devrait se produire à chaque fois que je charge la DataTable, non ?
    Or l'erreur ne se produit qu'une fois dans tout le code. c'est pour ça que ma méthode qui consiste à entourer la première occurrence de cette instruction dans un Try/catch marche. Je n'ai pas besoin de le faire si je réitère cette même instruction ailleurs.

    Evidemment, j'ai aussi regardé ce qui se passe dans ma SQL. Il s'agit d'une requête sur plusieurs tables dont certaines comportent des champs dont le nul est interdit relié à une autre table par un LEFT JOIN.
    Par exemple, en simplifiant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT table1.champ1, table2.champ2
    FROM table1
    LEFT JOIN table2 ON table1.clé = table2.clé
    ' dans cet exemple champ2 n'existe que dans table2 et n'accepte pas les valeurs nulles dans table2 
    ' mais la requête peut aboutir à afficher un champ2 nul en toute logique. 
    ' C'est le principe même du LEFT JOIN

    - Pourquoi l'erreur ne se produit qu'une fois dans le code ?
    - Eventuellement, qqun a-t-il une solution pour supprimer "proprement" l'erreur ?

  2. #2
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2012
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2012
    Messages : 175
    Points : 151
    Points
    151
    Par défaut
    Bonjour

    Evidemment, j'ai aussi regardé ce qui se passe dans ma SQL. Il s'agit d'une requête sur plusieurs tables dont certaines comportent des champs dont le nul est interdit relié à une autre table par un LEFT JOIN.
    Pour être sur que le "NULL non autoriser" n'est pas la souce du Pb, tu peux essayer de

    1: autoriser le null pour cette colonne et tester ton code

    ou bien

    2: tu cré un nouveau dataadapter test et une nouvelle datatable test par code et appliquer le FILL


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
            Dim DATest As New SqlDataAdapter("Select ....", Connexion)
            Dim DataTableTest AS New DataTable
            DATest.Fill(DataTableTest)

    et peut être un "Clear" du dataset avant de faire Le FILL ca va regler le problème

    A+

Discussions similaires

  1. [2.x] Erreur sur chargement de fichier
    Par fatenfacebok dans le forum Symfony
    Réponses: 9
    Dernier message: 17/02/2013, 20h26
  2. [SP-2007] Erreur sur chargement WebPart
    Par KILLER28 dans le forum SharePoint
    Réponses: 5
    Dernier message: 05/08/2011, 12h19
  3. Erreur lors du chargement d'un nouveau JAR sur TomCat
    Par Lolitaaa dans le forum Tomcat et TomEE
    Réponses: 1
    Dernier message: 21/01/2010, 13h29
  4. Erreur sur chargement KML
    Par Unusual dans le forum IGN API Géoportail
    Réponses: 15
    Dernier message: 29/12/2009, 13h16
  5. Réponses: 7
    Dernier message: 31/03/2008, 14h31

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