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
Partager