Hallo an alle VB.netler,
Ich steh vor einem Problem, dessen Lösung mich nicht ganz erreicht. Nicht mal ünber google, auch wenn ich Hinweise gefunden habe.
Ich fülle ein DataGridView per Abfrage auf eine SQL Server 2008 DB. Diese Abfrage beinhaltet INNER JOINS auf mehrere Tabellen. Das funktioniert auch.
Wenn ich nun aber Datensatzänderungen in die DB zurückschreiben will, beginnt bei mir der Horror.
Ein dynamisches UpdateCommand des SqlAdapters kann wohl nicht für DataSources, die aus einer Abfrage auf mehrere Tabellen bestehen, ausgeführt werden. Leuchtet mir bis zu einem bestimmten Punkt ein.
ABER: wie kann ich nun hier ein UPDATE ausführen, dass die, im DataGridView gemachten Änderungen an Datensätzen auch in die DB zurückgeschrieben werden??
Ich weiß, evtl. schwer nachzuvollziehen, daher ein Beispiel:
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
DBcon.myQueryStr = "SELECT Auftrag.ID, Auftrag.AuNr AS 'Auftrag', Auftrag.Datum, Kunde.Firma AS 'Auftraggeber', Auftrag.vPLZ AS 'von PLZ', Auftrag.vOrt AS 'von Ort', " & _
"Auftrag.vLand AS 'von Land', Auftrag.nPLZ AS 'nach PLZ', Auftrag.nOrt AS 'nach Ort', Auftrag.nLand AS 'nach Land', Auftrag.Sendung, Auftrag.Gewicht, Einheit.Einheit, " & _
"Auftrag.FRPreis AS 'Frachtpreis', Untern.Firma AS 'Frachtführer', Auftrag.TUPreis, Auftrag.Rechnung, Auftrag.Gewinn, Auftrag.Kennz AS 'Kennzeichen', " & _
"Auftrag.DispoNr, Auftrag.ErfGef AS 'Erfasst & Gefaxt', Status.ID AS 'Status'" & _
"FROM Auftrag"
DBcon.sqlAdapter.SelectCommand = New SqlClient.SqlCommand(DBcon.myQueryStr, DBcon.con)
'DBcon.sqlAdapter.SelectCommand = New SqlClient.SqlCommand(DBcon.myQueryStr, DBcon.con)
DBcon.sqlAdapter.Fill(DBcon.sqlSet, "Auftrag")
'DBcon.myTable = DBcon.sqlSet.Tables("Auftrag")
'DBcon.mybinding.DataSource = DBcon.myTable
'GlobVars.uf.Controls("dgvAUF").DataSource = DBcon.myTable
If DBcon.sqlSet.Tables("Auftrag").Rows.Count = 0 Then
NoDSFound("Transportaufträge")
Exit Sub
End If
GlobVars.uf.Text = "Transportaufträge"
GlobVars.uf.Show()
GlobVars.uf.Controls("dgvAUF").DataSource = DBcon.sqlSet.Tables("Auftrag")
GlobVars.uf.Controls("dgvAUF").DataSource = DBcon.mybinding
GlobVars.uf.Controls("dgvAUF").Columns("ID").Visible = False
GlobVars.uf.Controls("dgvAUF").Columns(DBcon.sqlSet.Tables("Auftrag").Columns.Count - 1).Visible = False
GlobVars.uf.Controls("dgvAUF").AllowUserToAddRows = False
GlobVars.uf.Controls("dgvAUF").ReadOnly = True
SetStaColors("dgvAUF")
GlobVars.uf.Controls("lbCOU").Text = GlobVars.uf.Controls("dgvAUF").RowCount
-----------------------------------------------------------------------------------------------------------------------------------------------------------------
Falls noch mehr info benötigt wird, einfach sagen.
Vielen Dank schon mal für die Hilfe
Grüße
Kai
Programmieren - alles kontrollieren 4.934 Themen, 20.613 Beiträge
n meiner DB gibt es eine Tabelle nur mit Kundendaten (KdNr, Firma, Adresse, Tel, usw) und auch eine mit Aufträgen die eine Spalte beinhaltet in der nicht der "Kundenname" bzw. "Firmenname", sondern die "KdNr" steht.
Das würde ich nun nicht gerade als "Besonderheit" bezeichnen. Das ist gängige Praxis (Stichwort "Normalisierung")...
Die Besonderheit sehe ich eher darin, dass Du unbedingt diese gejointe Tabelle komplett editierbar machen willst. Das erscheint mir nicht unbedingt sinnvoll. Änderungen an der Tabelle Firma würde ich tendenziell auch eher nur über einen eigenen Dialog erlauben. Da drückst du beim bearbeiten einmal zu oft die Tab Taste und schreibst weiter, und schon ist der Firmeneintrag kaputt...
Wird nun eine Zeile geändert, z.B. Auftrag.ID=1, gibt der Benutzer hier den Firmenname ein, z.B. "Bosch AG" und beim Klick auf "Speichern" soll dann über ein SELECT die "KdNr" aus der Tabelle "Kunden" ermittelt werden (sofern der Kunde existiert) und DIESE dann in die DB gespeichert werden. Ich denke somit sollte ich den von dir zurecht beschriebenen Problem aus dem Weg gehen.
Was passiert wenn mehrere Zeilen geändert wurden bevor auf Speichern gedrückt wurde?
Btw.: Was machst Du eigentlich mit Firmen/Kunden deren Name sich irgendwann mal ändert? ;-)
Das würde ich nun nicht gerade als "Besonderheit" bezeichnen. Das ist gängige Praxis (Stichwort "Normalisierung")...
Die Besonderheit sehe ich eher darin, dass Du unbedingt diese gejointe Tabelle komplett editierbar machen willst. Das erscheint mir nicht unbedingt sinnvoll. Änderungen an der Tabelle Firma würde ich tendenziell auch eher nur über einen eigenen Dialog erlauben. Da drückst du beim bearbeiten einmal zu oft die Tab Taste und schreibst weiter, und schon ist der Firmeneintrag kaputt...
Wird nun eine Zeile geändert, z.B. Auftrag.ID=1, gibt der Benutzer hier den Firmenname ein, z.B. "Bosch AG" und beim Klick auf "Speichern" soll dann über ein SELECT die "KdNr" aus der Tabelle "Kunden" ermittelt werden (sofern der Kunde existiert) und DIESE dann in die DB gespeichert werden. Ich denke somit sollte ich den von dir zurecht beschriebenen Problem aus dem Weg gehen.
Was passiert wenn mehrere Zeilen geändert wurden bevor auf Speichern gedrückt wurde?
Btw.: Was machst Du eigentlich mit Firmen/Kunden deren Name sich irgendwann mal ändert? ;-)