Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   "instead of delete" in MySQL (https://www.delphipraxis.net/173167-instead-delete-mysql.html)

Dragon27 10. Feb 2013 19:15

Datenbank: MySQL • Version: 5.6 • Zugriff über: uniDAC

"instead of delete" in MySQL
 
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!

DonManfred 11. Feb 2013 07:17

AW: "instead of delete" in MySQL
 
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.

taveuni 11. Feb 2013 10:12

AW: "instead of delete" in MySQL
 
Machs mit einem Trigger.

jobo 11. Feb 2013 10:39

AW: "instead of delete" in MySQL
 
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)

DeddyH 11. Feb 2013 10:44

AW: "instead of delete" in MySQL
 
Zitat:

Zitat von jobo (Beitrag 1202863)
- 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.

jobo 11. Feb 2013 11:13

AW: "instead of delete" in MySQL
 
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 ...

franktron 11. Feb 2013 15:18

AW: "instead of delete" in MySQL
 
Google ist mein Freund

http://entwickler-forum.de/showthrea...rn-mit-Trigger

DeddyH 11. Feb 2013 15:24

AW: "instead of delete" in MySQL
 
Und Du bist sicher, dass es dort um MySQL geht? Die Syntax sieht mir eher nach IB/FB aus.

franktron 11. Feb 2013 15:25

AW: "instead of delete" in MySQL
 
Zitat:

Zitat von DeddyH (Beitrag 1202903)
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 :evil:

Morphie 11. Feb 2013 15:27

AW: "instead of delete" in MySQL
 
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.


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:43 Uhr.
Seite 1 von 2  1 2      

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