MYSQL 5 und trigger

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • MYSQL 5 und trigger

    Hallo!

    Ich such eine elegante Lösung für folgendes Problem:

    Werden Datensätze per Update-Statement in der Tabelle "test" verändert, so sichert ein entsprechender Update-Trigger den kompletten Datenzatz in der Tabelle "log_test". Unter anderem werden auch die ID des Users, der den Datensatz verändert hat, gelogged. Damit kann ich jederzeit nachvollziehen, wer wann welche Veränderung an Datensätzen vorgenommen hat.
    Mein problem ist nun, dass bei einem Delete-Statement die User-ID nicht auftaucht ("delete from table test where id=23") - dementsprechend kann auch der Trigger nicht loggen, wer den Datensatz gelöscht hat.
    Wie kann ich dem Trigger jetzt noch den Parameter der $_SESSION[id] übergeben? Oder kennt jemand eine andere Lösung?

    Danke und Gruss

    Mirandus

  • #2
    Ich persönlich würde es für den elegantesten Weg halten wenn du in der Session ein Global Session Variable einrichtest (z. B. direkt nach dem db connect) SET @session_user := userid; ... auf die solltest Du dann auch via Trigger (INSERT/UPDATE/DELETE) zugreifen können ...
    carpe noctem

    [color=blue]Bitte keine Fragen per EMail ... im Forum haben alle was davon ... und ich beantworte EMail-Fragen von Foren-Mitgliedern in der Regel eh nicht![/color]
    [color=red]Hinweis: Ich bin weder Mitglied noch Angestellter von ebiz-consult! Alles was ich hier von mir gebe tue ich in eigener Verantwortung![/color]

    Kommentar

    Lädt...
    X