vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Mails senden, abrufen und decodieren - ganz easy ;-)  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

ADO.NET / Datenbanken
DeleteCommand für TableAdapterManager 
Autor: Elwomsa
Datum: 07.09.08 20:03

Hallo zusammen,

Ich hab ein Problem mit der Bearbeitung einer DataGridView Tabelle.

Zum Einsatz kommt Visual Studio 2008 Professional.

In einem Projekt wird durch einen Button eine 2. WindowsForm mit dem Namen Suchauftrag geöffnet. Darin ist in einem Splitt Container eine DataGridView Tabelle aus einer mdf Datanbank Buchkammer eingebettet, welche nicht in das aktuelle Projekt kopiert wurde/wird.

Wenn ich Daten einfügen will, funktioniert das einwandfrei und ich kann diese Daten auch abspeichern. Wenn ich aber Daten lösche und danach auf abspeichern klicke, gibt mir der Debugger folgende Fehlermeldung aus:

Aktualisieren erfordert einen gültigen DeleteCommand, wenn eine DataRow-Auflistung mit gelöschten Zeilen weitergegeben wird.

Die Codezeile: Me.TableAdapterManager.UpdateAll(Me.BuchkammerDataSet)
wird dabei gelb hinterlegt.

Der komplette Code für diese Windows Form Suchauftrag lautet:

Public Class Suchauftrag
 
    Private Sub BeendenToolStripMenuItem_Click(ByVal sender As System.Object, _
      ByVal e As System.EventArgs) Handles BeendenToolStripMenuItem.Click
        ' Feierabend Button schließt das Programm
        Application.Exit()
    End Sub
 
 
    ' Hier sollte die Suchabfrage gestartet werden
    Private Sub SucheStartenToolStripMenuItem_Click(ByVal sender As _
      System.Object, ByVal e As System.EventArgs) Handles _
      SucheStartenToolStripMenuItem.Click
 
    End Sub
 
    Private Sub Suchauftrag_Load(ByVal sender As System.Object, ByVal e As _
      System.EventArgs) Handles MyBase.Load
        'TODO: Diese Codezeile lädt Daten in die Tabelle 
        ' "BuchkammerDataSet.Suchauftrag". Sie können sie bei Bedarf 
        ' verschieben oder entfernen.
        Me.SuchauftragTableAdapter.Fill(Me.BuchkammerDataSet.Suchauftrag)
 
    End Sub
    Private Sub SuchauftragBindingNavigatorSaveItem_Click(ByVal sender As _
      System.Object, ByVal e As System.EventArgs) Handles _
      SuchauftragBindingNavigatorSaveItem.Click
        Me.Validate()
        Me.SuchauftragBindingSource.EndEdit()
        Me.TableAdapterManager.UpdateAll(Me.BuchkammerDataSet)
 
    End Sub
 
 
 
End Class
Wo liegt der Fehler? Warum kann ich keine Daten löschen ohne Fehlermeldung? Wie lautet der DeleteCommand der hier noch fehlt?

Hirarchische Aktualisierung ist auf true.
Primärschlüssel ist in der Tabelle verteilt.

Ich hab nun schon 3 Stunden rumgegoogelt und bin nicht weiter gekommen.

Gruß Uwe
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: DeleteCommand für TableAdapterManager 
Autor: ModeratorFZelle (Moderator)
Datum: 08.09.08 10:07

Diese Fehlermeldung steht hier schon so oft in diesem Forum, das es mich wundert, das du die noch nicht gefunden hast.

Wenn der Tabeladapter kein DeleteCommand erstellt bekommen hat, liegt es zu 99% daran,
das die Tabelle keinen Primary Key hat.
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: DeleteCommand für TableAdapterManager 
Autor: Elwomsa
Datum: 08.09.08 10:14

Ah ja, hatte ich vergessen zu erwähnen, der Primary Key war ebenfalls schon vorher gesetzt und es hat nicht gefunzt.

Nun bin ich wohl durch Zufall auf dem letzten 1% Fehler gelandet :-/

Gruß Uwe
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: DeleteCommand für TableAdapterManager 
Autor: Elwomsa
Datum: 08.09.08 10:17

So, hab den "Fehler" gefunden und möchte ihn für spätere Generationen gern hinterlassen.

1. Datenquellen Ansicht öffnen

2. Auf DataSet mit Designer bearbeiten klicken

3. Im neu geöffnetem Fenster unter (Tabelle)TableAdapter Fill,GetData () -> Rechtsklick -> Konfigurieren

4. Im nächsten Fenster auf Weiter -> Zu generierende Methode auswählen -> Standartmäßig sind wohl nur die oberen 2 Haken gesetzt. Die untere CheckBox Methoden erstellen, um Updates direkt an die Datenbank zu senden wird nun auch aktiviert.

5. Nochmal auf Weiter und dann auf Fertig stellen. Das wars.

Nun werden auch gelöschte Einträge nach dem Klick auf Speichern ohne Fehlermeldung erfolgreich in der Datenbank aktualisiert.

Gruß Uwe

Beitrag wurde zuletzt am 08.09.08 um 10:18:52 editiert.
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: DeleteCommand für TableAdapterManager 
Autor: ModeratorDaveS (Moderator)
Datum: 08.09.08 10:30

Danke. Mit der Suche hättest du aber doch leicht die Antwort hier gefunden.
http://www.vbarchiv.net/forum/id24_i10665t10662.html

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: DeleteCommand für TableAdapterManager 
Autor: Elwomsa
Datum: 08.09.08 11:05

Na ja, eben nicht.

Diese Antwort hatte ich schon gefunden. Sie hat mir aber nicht weiter geholfen, da der Primärschlüssel in der Tabelle schon gesetzt war.

Auch mit dem Code aus dem Thread:

TestDBDataSet.TestTabelle.Rows(0).Delete()
Me.TestTabelleTableAdapter.Update(Me.TestDBDataSet.TestTabelle)

konnte ich nichts anfangen, da der TableAdapterManager solchen Code bei der Verbindung einer DataGridView mit dem Projekt in Visual Studio 2008 nicht generiert.

Gruß Uwe
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: DeleteCommand für TableAdapterManager 
Autor: ModeratorDaveS (Moderator)
Datum: 08.09.08 11:16

Naja, eben doch. Da steht: Wenn TableAdapter den Delete-Befehl nicht generiert hat...(Oder) du hast die Option beim Assistenten ausgeschaltet.

Man muss ja nur richtig lesen Die Option ist übrigens standardmässig eingeschaltet.

________
Alle Angaben ohne Gewähr. Keine Haftung für Vorschläge, Tipps oder sonstige Hilfe, falls es schiefgeht, nur Zeit verschwendet oder man sonst nicht zufrieden ist

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel