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 :

OleDbCommandBuilder Clé primaire non reconnue


Sujet :

ADO.NET

  1. #1
    Futur Membre du Club
    Profil pro
    retired
    Inscrit en
    Janvier 2003
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : retired

    Informations forums :
    Inscription : Janvier 2003
    Messages : 8
    Points : 9
    Points
    9
    Par défaut OleDbCommandBuilder Clé primaire non reconnue
    Bonjour

    J'essaie la commande Update sur un OleDbDataAdapter, mais il me donne une erreur :
    "La génération SQL dynamique de UpdateCommand n'est pas prise en charge pour un SelectCommand qui ne retourne pas des informations de colonne clé."

    Le OleDbCommandBuilder ne peut pas exécuter la commande Update car il ne trouve pas la clé primaire qui existe pourtant dans ma table Access (Entier, Nul interdit, Indexé sans doublons). Aucune clé n'est nulle (impossible).

    Ma requête SQL : "SELECT * FROM tbConfig WHERE n > 0;" (n étant ma clé primaire)

    La commande générée par OleDbCommand Builder (la dernière clause semble reconnaitre la clé):
    "UPDATE tbConfig SET Rep = ?, Last = ?, numord = ?, fics = ?, n = ? WHERE (((? = 1 AND Rep IS NULL) OR (Rep = ?)) AND ((? = 1 AND Last IS NULL) OR (Last = ?)) AND ((? = 1 AND numord IS NULL) OR (numord = ?)) AND ((? = 1 AND fics IS NULL) OR (fics = ?)) AND (n = ?))"
    Je ne sais pas à quoi correspondent les "(?=1 AND champ IS NULL)", mais je sais que CommandBuilder contrôle tous les champs non modifiés et non seulement la clé primaire.

    J'ai même spécifié la clé primaire avec le code suivant sans résultat :
    ds.Tables("tbConfig").Columns("n").Unique = True

    J'ai converti ma base en SQL Compact Edition et le même code (SqlCe au lieu de OleDb) fonctionne parfaitement.

    Code SQL généré, assez similaire à celui de OleDb :
    "UPDATE [tbConfig] SET [Rep] = @p1, [Last] = @p2, [Numord] = @p3, [Fic] = @p4, [n] = @p5 WHERE (((@p6 = 1 AND [Rep] IS NULL) OR ([Rep] = @p7)) AND ((@p8 = 1 AND [Last] IS NULL) OR ([Last] = @p9)) AND ((@p10 = 1 AND [Numord] IS NULL) OR ([Numord] = @p11)) AND ((@p12 = 1 AND [Fic] IS NULL) OR ([Fic] = @p13)) AND ([n] = @p14))"

    S'agit-il d'un bug dans OleDb ? Comment le contourner ?

    Un Update manuel est envisageable pour cette table qui comporte 5 champs, mais j'en ai une autre qui en comporte plus de 60 !!

    Et je ne peux pas passer en SQL Compact, car certains utilisateurs utilisent Access pour créer des requêtes.

    Merci à l'avance pour vos réponses

    Denis

  2. #2
    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
    n étant ma clé primaire
    Est-ce vraiment la clé primaire access (petite clé devant le champ en mode creation de la table sous Access ) et pas seulement une clé unique?

    Dans "(?=1 AND champ IS NULL)", la valeur du paramètre correspondant au "?" est 1 si <ValeurOriginale du champ = NULL> et 0 sinon.
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

Discussions similaires

  1. [Lomboz] [JBoss] JBoss 3.2.6 non reconnu par Lomboz ?
    Par romain3395 dans le forum Eclipse Java
    Réponses: 4
    Dernier message: 17/12/2004, 16h35
  2. Commandes non reconnues.
    Par Manu' dans le forum Administration système
    Réponses: 3
    Dernier message: 07/10/2004, 17h09
  3. [EJB] [JSP] Méthode EJB non reconnue dans jsp
    Par stago dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 06/07/2004, 09h52
  4. Creation de table, caractère non reconnu
    Par Missvan dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 17/02/2004, 13h28
  5. xslt_create() non reconnu
    Par BRAUKRIS dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 11/12/2003, 14h43

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