AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken "instead of delete" in MySQL
Thema durchsuchen
Ansicht
Themen-Optionen

"instead of delete" in MySQL

Ein Thema von Dragon27 · begonnen am 10. Feb 2013 · letzter Beitrag vom 11. Feb 2013
Antwort Antwort
Seite 1 von 2  1 2      
Dragon27

Registriert seit: 20. Nov 2003
Ort: Aßling
543 Beiträge
 
Delphi XE6 Enterprise
 
#1

"instead of delete" in MySQL

  Alt 10. Feb 2013, 20:15
Datenbank: MySQL • Version: 5.6 • Zugriff über: uniDAC
Hallo,

vielleicht könnt ihr mir bei einem "kleinen" Datenbankproblem helfen.

Ich möchte allgemein das Löschen in der MySQL Datenbank unterbinden. Stattdessen soll im Datensatz das Feld "deleted" auf 1 gesetzt werden.
In Oracle wäre das kein Problem, da man hier ja instead of delete verwenden kann. Jedoch bietet dies MySQL nicht.
Vielleicht wisst ihr eine gute Lösung.

Danke!
Delphi is ......... DELPHI!!
  Mit Zitat antworten Zitat
DonManfred

Registriert seit: 8. Nov 2007
Ort: Düren
55 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 08:17
Baue Dir eine Funktion/Procedure über die du alle SQLs absetzt. Und wenn da ein DELETE verwendet wird dann baust du dir selber ein Update-Statement um delted auf true/1 zu setzen.

Alternativ kannst Du dem SQL-Benutzer die rechte nehmen DELTE auszuführen und schreibst die Programme um das sie anstelle von DELETE ein UPDATE durchführen.
  Mit Zitat antworten Zitat
taveuni

Registriert seit: 3. Apr 2007
Ort: Zürich
534 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 11:12
Machs mit einem Trigger.
Die obige Aussage repräsentiert meine persönliche Meinung.
Diese erhebt keinen Anspruch auf Objektivität oder Richtigkeit.
  Mit Zitat antworten Zitat
jobo

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

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 11:39
Ich weiß nicht, ob das noch aktuell ist, aber es war glaub ich so oder ähnlich:
- Before Delete Trigger, der absichtlich einen Fehler produziert. Damit ist das Löschen verhindert.
- After Delete Trigger, den gewünschten Wert ändern, also Update (oder doch löschen und mit geänderten Werten wieder einfügen)
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#5

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 11:44
- Before Delete Trigger, der absichtlich einen Fehler produziert. Damit ist das Löschen verhindert.
Das war auch mein erster Gedanke, leider musste ich im Inet lesen, dass das bei MySQL nicht möglich sein soll. Dummerweise stand da keine Version dabei, es kann also auch sein, dass sich das mittlerweile geändert hat, man müsste es also einfach einmal mit der eigenen Version ausprobieren.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
jobo

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

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 12:13
Also ich meine, man kann das Löschen selbst im Before Delete nicht verhinden, deswegen "provoziert" man den Fehler, z.B.
Code:
Select [SpaltenNamenDenEsNICHTgibt] from mytable
und verhindert damit eben zunächst das Löschen. WEnn man dann noch geänderte Werte braucht, dann mittels AfteDelete ...
Gruß, Jo
  Mit Zitat antworten Zitat
franktron

Registriert seit: 11. Nov 2003
Ort: Oldenburg
1.446 Beiträge
 
Delphi 10.2 Tokyo Enterprise
 
#7

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 16:18
Google ist mein Freund

http://entwickler-forum.de/showthrea...rn-mit-Trigger
Frank
Tux sein Lieblingsquellcode
While anzfische<TuxSatt do begin
Fisch:=TFisch.Create; Tux.EssenFisch(Fisch); Fisch.Free;inc(anzfische); end;
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#8

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 16:24
Und Du bist sicher, dass es dort um MySQL geht? Die Syntax sieht mir eher nach IB/FB aus.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
franktron

Registriert seit: 11. Nov 2003
Ort: Oldenburg
1.446 Beiträge
 
Delphi 10.2 Tokyo Enterprise
 
#9

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 16:25
Und Du bist sicher, dass es dort um MySQL geht? Die Syntax sieht mir eher nach IB/FB aus.
Hast recht google BÖSE ist
Frank
Tux sein Lieblingsquellcode
While anzfische<TuxSatt do begin
Fisch:=TFisch.Create; Tux.EssenFisch(Fisch); Fisch.Free;inc(anzfische); end;
  Mit Zitat antworten Zitat
Morphie

Registriert seit: 27. Apr 2008
Ort: Rahden
630 Beiträge
 
#10

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 16:27
kann man nicht vor dem Löschen eine Kopie des Datensatzes mittels Trigger anlegen? Hierbei muss man natürlich auf Unique-Keys achten...
Je nachdem, was überhaupt wirklich gewollt ist, wäre es auch möglich, den Datensatz in eine "Archiv-Tabelle" zu verschieben/kopieren... Dazu noch eine Information, wer und wann den Datensatz gelöscht hat usw.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 13:53 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