Programmieren - alles kontrollieren 4.934 Themen, 20.613 Beiträge

VB.net 2010: Daten aus DataSet zurück in DB schreiben

Neo3000 / 6 Antworten / Flachansicht Nickles

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

bei Antwort benachrichtigen
Neo3000 Borlander „ Meinst Du die Auftrag.ID? In gewisser Weise sind die Zeile schon eindeutig....“
Optionen

Da hast du recht, so würde ich auch Schwierigkeiten stoßen.
Allerdings besteht genau hier eine kleine "Besonderheit" die ich erstmal erläutern muss damit man versteht was ich meine. Also:

In 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.
In meinem DataGridView binde ich die Tabelle "Aufträge", lasse aber über die Joins nicht die "KdNr" sondern den "Firmenname" anzeigen. In den Quelldaten der Tabelle "Aufträge" steht aber weiterhin die "KdNr".
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.

Der Grund für so ein "gewurschtel", ich wollte damit möglichst wenig Datenredundanzen in der DB erzeugen.
Dass nicht z.B der Firmenname des Kunden einmal in der Tabelle "Kunden" UND dann nochmal in der Tabelle "Aufträge" gespeichert wird.
Wenn ich aber da dabei bin murgs zu machen, einfach sagen ;-).

bei Antwort benachrichtigen