| |
![zurück](../images/b_zurueck.gif)
VB.NET - FortgeschritteneLöschproblem | | ![](../images/trans.gif) | Autor: rub_ | Datum: 20.01.05 13:03 |
| Hi, ich benutze die folgende Funktion um meine Veränderungen an den DataTable-Einträgen zu speichern. Public Shared Function UpdateDataBase(ByVal frm_Formular As _
Windows.Forms.Form, ByVal ds_DataSetObjekt As DataSet, ByVal _
str_Backendname As String)
'Die Funktion Aktualisiert die Daten in der datenbank mit den aktuellen
' Daten des Datasets.
'Fehlerabfangroutine zum Schutz der gesammten Funktion
Try
'Interne Datenbankanbindung
Dim con_DBconnection As New System.Data.OleDb.OleDbConnection()
Dim ds_tbl_currentTabelle As DataTable
'Fehlerabfangroutine greift ein, wenn der Eingabefokus nicht von
' der zu speichernden Tabelle genommen werden kann, oder wenn
'Die Verbindung zur Datenbank fehlschlägt, oder wenn das Update
' nicht durchgeführt werden kann.
Try
'Datenbank wird geöffnet. Rückgabewert von eQM_getDBConnection
' ist die offene Datenbank.
con_DBconnection = eQM_getDBConnection(ds_DataSetObjekt, _
str_Backendname)
'Die Schleife durchläuft alle Tabellen des Datasets.
For Each ds_tbl_currentTabelle In ds_DataSetObjekt.Tables
'Eingabe in der dem Formular zugrundeliegenden Tabelle
' beenden.
frm_Formular.BindingContext(ds_DataSetObjekt, _
ds_tbl_currentTabelle.TableName).EndCurrentEdit()
'Sql-String für den Datenadapter.
Dim str_Sql As String = "SELECT * FROM " & _
ds_tbl_currentTabelle.TableName
'Datenadapter wird konfiguriert, um die aktuelle Tabelle
' mit der Datenbank ab zu gleichen.
Dim ds_adp_OleDbDA As New _
System.Data.OleDb.OleDbDataAdapter(str_Sql, _
con_DBconnection)
'Der CommandBuilder ermöglicht die Abänderung in der
' Datenbank über Update, so dass nur veränderte Datensätze
' gespeichert werden.
Dim cb As New OleDb.OleDbCommandBuilder(ds_adp_OleDbDA)
ds_adp_OleDbDA.Update(ds_DataSetObjekt, _
ds_tbl_currentTabelle.TableName)
Next
Catch ex As Exception
MsgBox(ex.Message)
Finally
'Verbindung schließen, egal ob die Ausnahme ausgelöst wurde
' oder nicht.
con_DBconnection.Close()
End Try
Catch ex As Exception
MsgBox(ex.Message)
End Try
End Function Wenn ich jetzt aber eine komplette Zeile gelöscht habe, bekomme ich eine Fehlermeldung. : Dynamische SQL-Generierung wird gegen einen SelectCommand, der keine Basistabelleninformationen zurückgibt, nicht unterstützt.
Der Fehler tritt direkt in der Zeile vor dem Next auf. Irgendwo ja auch klar, denn ich habe einen Select - SQL - String, anstelle eines Delete Strings, denke ich.
Wie kann ich die Funktion anpassen, damit der Eintrag in der Datenbank gelöscht wird? Hab leider noch keine Erfahrung mit Delete.
Gru? Rub
(PS: Besuch doch mal meine Seiten http://e-liquids.de und http://jjpassion.de) | ![](../images/trans.gif) |
![](../images/48x48/info.gif) | 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 |
![nach oben](../images/b_top.gif) ![zurück](../images/b_zurueck.gif) |
|
TOP! Unser Nr. 1 ![Flexibles DataGrid- und ListView-Control](../images/werbung/sevdatagrid3_100x100.jpg)
Neu! sevDataGrid 3.0
Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. Weitere InfosTipp des Monats Access-Tools Vol.1 ![Access-Tools CD Vol.1](../images/werbung/apvol1_68x100.gif)
Über 400 MByte Inhalt
Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB
Nur 24,95 EURWeitere Infos
|
|
|
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
|
|