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
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, 19: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, 07: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
528 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 10: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, 10: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.548 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: "instead of delete" in MySQL

  Alt 11. Feb 2013, 10: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, 11: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
Antwort Antwort


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 21:27 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