Hallo Ich habe bei einem DataTable einen Datensatz hinzugefügt und wollte mit folgendem Code ein Update durchführen, OleDbCommandBuilder cb = new OleDbCommandBuilder(da); conn.Open(); da.Update(dtImpParamUpd); conn.Close(); und es kommt die Fehlermeldung "Syntaxfehler in der INSERT INTO-Anweisung." Ich habe schon zum x-tem Mal die Spaltennamen überprüft und konnte keinen Fehler finden. Diese Anweisung wird doch vom CommandBuilder selbst generiert oder? Wie kann ich mir diese Anweisung ansehen? Kann mir bitte jemand helfen? Nachbar in Not. mfg Klatec
Ein bisschen wenig Code:
1 | // irgendwo sollte es folgende Sachen geben
|
2 | |
3 | dbConnection = new OleDbConnection(connStr); |
4 | dbAdapter = new OleDbDataAdapter(); |
5 | dbAdapter.InsertCommand = new OleDbCommand("dein Insert", dbConnection); |
6 | // hier könnte man sich die Parameter auch selbst zusammen bauen
|
7 | // dbAdapter.InsertCommand.Parameters.Add(...);
|
8 | dbCmdBuider = new OleDbCommandBuilder(dbAdapter); |
9 | |
10 | dbConnection.open(); |
11 | |
12 | dbCmdBuilder.GetInsertCommand(); |
13 | |
14 | dbAdapter.Update(dataSet, tableName); |
15 | |
16 | dbConnection.close(); |
Hallo Mit folgendem Code kommt noch immer die selbe Fehlermeldung. //Verbindung mit der Tabelle ImpParam (Importparameter) string conStr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= " + strDb; conn = new OleDbConnection(conStr); string insSql = "INSERT INTO ImpParam (ParamBez, Firma,ImpDatum, Quellformat, Quellpfad, GO, END, Z1, Z2," + " Z3, Z4, Z5, Z6, Z7, Z8, Z9, Z10,Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, Q10, A1, A2, A3, A4, A5, A6," + " A7, A8, A9, A10) VALUES ( @p1,@p2,@p3,@p4,@p5,@p6,@p7,@p8,@p9,@p10,@p11,@p12,@p13,@p14,@p15,@p16," + " @p17,@p18,@p19,@p20,@p21,@p22,@p23,@p24,@p25,@p26,@p27,@p28,@p29,@p30,@p 31,@p32,@p33,@p34,@p35,@p36,@p37)"; da.InsertCommand = new OleDbCommand(insSql, conn); // DataAdapter-Objekt erzeugen: da.InsertCommand.Parameters.Add("@p1", OleDbType.VarWChar, 255, "ParamBez"); da.InsertCommand.Parameters.Add("@p2", OleDbType.VarWChar, 100, "Firma"); da.InsertCommand.Parameters.Add("@p3", OleDbType.Date, 20, "ImpDatum"); da.InsertCommand.Parameters.Add("@p4", OleDbType.VarWChar, 100, "Quellformat"); da.InsertCommand.Parameters.Add("@p5", OleDbType.VarWChar, 100, "Quellpfad"); da.InsertCommand.Parameters.Add("@p6", OleDbType.Integer, 6, "GO"); da.InsertCommand.Parameters.Add("@p7", OleDbType.Integer, 6, "END"); da.InsertCommand.Parameters.Add("@p8", OleDbType.VarWChar, 100, "Z1"); da.InsertCommand.Parameters.Add("@p9", OleDbType.VarWChar, 100, "Z2"); da.InsertCommand.Parameters.Add("@p10", OleDbType.VarWChar, 100, "Z3"); da.InsertCommand.Parameters.Add("@p11", OleDbType.VarWChar, 100, "Z4"); da.InsertCommand.Parameters.Add("@p12", OleDbType.VarWChar, 100, "Z5"); da.InsertCommand.Parameters.Add("@p13", OleDbType.VarWChar, 100, "Z6"); da.InsertCommand.Parameters.Add("@p14", OleDbType.VarWChar, 100, "Z7"); da.InsertCommand.Parameters.Add("@p15", OleDbType.VarWChar, 100, "Z8"); da.InsertCommand.Parameters.Add("@p16", OleDbType.VarWChar, 100, "Z9"); da.InsertCommand.Parameters.Add("@p17", OleDbType.VarWChar, 100, "Z10"); da.InsertCommand.Parameters.Add("@p18", OleDbType.VarWChar, 100, "Q1"); da.InsertCommand.Parameters.Add("@p19", OleDbType.VarWChar, 100, "Q2"); da.InsertCommand.Parameters.Add("@p20", OleDbType.VarWChar, 100, "Q3"); da.InsertCommand.Parameters.Add("@p21", OleDbType.VarWChar, 100, "Q4"); da.InsertCommand.Parameters.Add("@p22", OleDbType.VarWChar, 100, "Q5"); da.InsertCommand.Parameters.Add("@p23", OleDbType.VarWChar, 100, "Q6"); da.InsertCommand.Parameters.Add("@p24", OleDbType.VarWChar, 100, "Q7"); da.InsertCommand.Parameters.Add("@p25", OleDbType.VarWChar, 100, "Q8"); da.InsertCommand.Parameters.Add("@p26", OleDbType.VarWChar, 100, "Q9"); da.InsertCommand.Parameters.Add("@p27", OleDbType.VarWChar, 100, "Q10"); da.InsertCommand.Parameters.Add("@p28", OleDbType.Boolean, 1, "A1"); da.InsertCommand.Parameters.Add("@p29", OleDbType.Boolean, 1, "A2"); da.InsertCommand.Parameters.Add("@p30", OleDbType.Boolean, 1, "A3"); da.InsertCommand.Parameters.Add("@p31", OleDbType.Boolean, 1, "A4"); da.InsertCommand.Parameters.Add("@p32", OleDbType.Boolean, 1, "A5"); da.InsertCommand.Parameters.Add("@p33", OleDbType.Boolean, 1, "A6"); da.InsertCommand.Parameters.Add("@p34", OleDbType.Boolean, 1, "A7"); da.InsertCommand.Parameters.Add("@p35", OleDbType.Boolean, 1, "A8"); da.InsertCommand.Parameters.Add("@p36", OleDbType.Boolean, 1, "A9"); da.InsertCommand.Parameters.Add("@p37", OleDbType.Boolean, 1, "A10"); // DataAdapter-Objekt erzeugen: da.MissingSchemaAction = MissingSchemaAction.AddWithKey; // Speichern der Änderungn in der DB OleDbCommandBuilder cb = new OleDbCommandBuilder(da); cb.GetInsertCommand(); conn.Open(); da.Update(dsImpParamUpd,"ImpParam"); conn.Close();
Hallo Ich habe den Fehler gefunden. Es war der Spaltenname 'GO' der diesen verursachte.
Nur zur Info: Der DataAdapter 'da' öffnet und schliesst die Connection beim Update() automatisch. conn.Open() und conn.Close() , müssen also nicht extra angegeben werden.
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.