AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Löschen von Datenbankeinträgen
Thema durchsuchen
Ansicht
Themen-Optionen

Löschen von Datenbankeinträgen

Ein Thema von Flash68 · begonnen am 27. Jan 2012 · letzter Beitrag vom 30. Jan 2012
Antwort Antwort
Seite 1 von 3  1 23      
Flash68

Registriert seit: 24. Apr 2006
102 Beiträge
 
Delphi XE2 Architect
 
#1

Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 08:06
Datenbank: MSSQL • Version: 2008R2 Express • Zugriff über: Delphi/Ado
Hallo zusammen,

ich habe in einer Datenbank mehrere Verknüpfungstabellen für M zu N Beziehungen, aus diesen möchte ich Einträge löschen. Diese sind über ein ADO-Dataset an die Haupttabelle angebunden und mit ihnen werden auch die Einträge aus der Listabelle angezeigt. Deshalb gibt es beim Löschen dann folgenden Fehler:

Nicht genügend Schlüsselinformationen zum Aktualisieren

Kann mir jemand helfen wie ich nur die Einträge aus der Verknüpfungstabelle lösche ohne das er versucht die aus der Listtabelle mit zu löschen?

Gruß

Flash
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#2

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 08:29
Das geht vielleicht nicht, kommt auf das Datenmodel an.

Schau Dir die Foreign Keys auf der Tabelle an und die Primary Keys
Vermutlich sind es 2 PK, die musst Du im Delete angeben.
Gruß, Jo
  Mit Zitat antworten Zitat
Flash68

Registriert seit: 24. Apr 2006
102 Beiträge
 
Delphi XE2 Architect
 
#3

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 09:08
Die Verknüfungstabellen bestehen nur aus 2 Spalten die auf die Haupt- und listtabelle verweisen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 09:11
Die Kombination könnte trotzdem ein zusammengesetzter Primärschlüssel sein
Markus Kinzler
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#5

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 09:21
Wo und wie löscht Du denn?
Per Query? Im Dataset? Welche Tabelle, nur die Zwischentabelle?
Kannst Du SQL oder Quellcode posten?
Gruß, Jo
  Mit Zitat antworten Zitat
Flash68

Registriert seit: 24. Apr 2006
102 Beiträge
 
Delphi XE2 Architect
 
#6

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 09:32
Ich lösche mit:

ADODataSet.Delete

Wenn die Informationen aus der Listtabelle nicht in dem Dataset angegeben sind funktioniert das auch.

Ich bräuchte nur eine Möglichkeit wie ich das ausschliesse oder so.
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#7

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 09:35
Was ist denn die "Listtabelle"
Und wie ist das Dataset definiert?
Gruß, Jo
  Mit Zitat antworten Zitat
Flash68

Registriert seit: 24. Apr 2006
102 Beiträge
 
Delphi XE2 Architect
 
#8

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 10:16
Das Dataset wird über folgende Select-Anweisung angebunden:

select RS.Rechner_ID, RS.Speicher_ID, S.Bezeichnung, RS.Anzahl, S.Größe, S.Größe*Rs.Anzahl As Gesamt from Rechnerspeicher RS, Speicher S where RS.Rechner_ID =:ID and RS. Speicher_ID = S.ID

Die Haupttabelle ist Rechner, Verknüpfungstabelle ist Rechnerspeicher und die Listtabelle ist Speicher.
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#9

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 10:22
Auf dieser Basis kann der Server nicht entscheiden, wo er was löschen soll.
Wenn Du nur die Verknüfung lösen willst, muss das Dataset auch nur diese Tabelle abbilden.
Das kannst Du bspw über eine Query lösen, die ein
Code:
Delete from Rechnerspeicher where [KeyPair=..]
absetzt. Also unabhängig von Deinem Dataset.
Gruß, Jo
  Mit Zitat antworten Zitat
Flash68

Registriert seit: 24. Apr 2006
102 Beiträge
 
Delphi XE2 Architect
 
#10

AW: Löschen von Datenbankeinträgen

  Alt 27. Jan 2012, 11:03
Normal verwende ich nur folgende Selectanweisung:

Select * from Rechnereingabe where Rechner_ID =:ID

damit funktioniert es, nur bei der anderen berechne ich halt noch den Gesamtspeicher.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:33 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz