Letzten Query herrausfinden Oracle
Hallo!
Ich habe folgendes Problem.
Ich möchte gern selbst eine Log-Tabelle führen. Hierzu möchte ich den Nutzername, das ausgeführte Query und das dazugehörige Datum abspeichern. Den Name und das Datum habe ich bereits nun ist das Problem der Query. Das ganze soll in einem Trigger ablaufen.
Für das Query habe ich nun schon einige Zeit im Netz gesucht und folgendes gefunden:
select * from v$sql where first_load_time=(select max(first_load_time) from v$sql)
Mein Trigger sieht im Moment so aus:
create or replace
TRIGGER TESTLOG
AFTER INSERT ON TEST
BEGIN
INSERT INTO INSERTLOGS (insertedtable, inserterduser, insertdate) values ((select * from v$sql where first_load_time=(select max(first_load_time) from v$sql)),(SELECT USER FROM dual),null);
END;
So möchte ich diesen nun ausführen erhalte ich folgende Fehlermeldung:
Error(6,5): PL/SQL: SQL Statement ignored
Error(6,94): PL/SQL: ORA-00942: table or view does not exist
Ich arbeite auf einem 9er Oracle Server mit dem SQL-Developer und bin nun schon etwas am verzweifeln.
Führe ich das Select aus funktioniert es. Ich weis auch, dass man dies nur als sys_admin ausführen kann, wo gleich das zweite Problem liegt. Ich bracuhe eine Möglichkeit dies als normaler Nutzer abzufragen. Ich hoffe ihr könnt mir da Helfen.
MfG
Ich habe folgendes Problem.
Ich möchte gern selbst eine Log-Tabelle führen. Hierzu möchte ich den Nutzername, das ausgeführte Query und das dazugehörige Datum abspeichern. Den Name und das Datum habe ich bereits nun ist das Problem der Query. Das ganze soll in einem Trigger ablaufen.
Für das Query habe ich nun schon einige Zeit im Netz gesucht und folgendes gefunden:
select * from v$sql where first_load_time=(select max(first_load_time) from v$sql)
Mein Trigger sieht im Moment so aus:
create or replace
TRIGGER TESTLOG
AFTER INSERT ON TEST
BEGIN
INSERT INTO INSERTLOGS (insertedtable, inserterduser, insertdate) values ((select * from v$sql where first_load_time=(select max(first_load_time) from v$sql)),(SELECT USER FROM dual),null);
END;
So möchte ich diesen nun ausführen erhalte ich folgende Fehlermeldung:
Error(6,5): PL/SQL: SQL Statement ignored
Error(6,94): PL/SQL: ORA-00942: table or view does not exist
Ich arbeite auf einem 9er Oracle Server mit dem SQL-Developer und bin nun schon etwas am verzweifeln.
Führe ich das Select aus funktioniert es. Ich weis auch, dass man dies nur als sys_admin ausführen kann, wo gleich das zweite Problem liegt. Ich bracuhe eine Möglichkeit dies als normaler Nutzer abzufragen. Ich hoffe ihr könnt mir da Helfen.
MfG
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 120905
Url: https://administrator.de/contentid/120905
Ausgedruckt am: 26.11.2024 um 16:11 Uhr
4 Kommentare
Neuester Kommentar
Moin LordCillin,
ich denke, Du solltest da erst nochmals ein paar Annahmen überprüfen und verifizieren.
Was treibt Dich so tief in die Resignation? Wo siehst Du Hinweise, die diese These unterstützen könnten?
Mit plausibler Bergündung klappt das auch heutzutage noch.
Was sicherlich nicht funktionieren kann:
--> in eine 3-Spalten-Tabelle INSERTLOGS die ca 50 Spalten der v$sql-View + den angemeldeten USER + einen Null-Wert reinzutrümmern.
Da sind so viele Kinken drin, dass ich gar nicht weiß, wo ich anfangen soll.
a) wenn der Timestampwert per Dafault gestzt werden soll, dann muss das in der DDL der INSERTLOGS stehen und Du brauchst/Solltest/darfst keinen NULL-Wert übergeben. Sondern das Feld gar nicht absprechen.
b) Und statt SELECT * from v$SQL muss es sicher SELECT SQL_TEXT fron v$SQL heißen
Und dann poste bitte die DDLs der INSERTLOGS und die GRANTs auf diese Tabelle.
Und (optional) erzähl doch mal, WTF denn überhaupt der Plan hinter diesem Realisierungsversuch ist.
Grüße
Biber
ich denke, Du solltest da erst nochmals ein paar Annahmen überprüfen und verifizieren.
Führe ich das Select aus funktioniert es.
Okay, das glaube ich Dir. Ich weis auch, dass man dies nur als sys_admin ausführen kann
Aha.Was treibt Dich so tief in die Resignation? Wo siehst Du Hinweise, die diese These unterstützen könnten?
wo gleich das zweite Problem liegt
Nee, nee. Hier geht es nur um IT-Krams, Datenbanken, ein büschen Oracle. Nix "Probleme".Ich bracuhe eine Möglichkeit dies als normaler Nutzer abzufragen
Ja hey! In meiner Jugend haben wir den DBA um die Erteilung entsprechender Rechte gebetenMit plausibler Bergündung klappt das auch heutzutage noch.
Was sicherlich nicht funktionieren kann:
INSERT INTO INSERTLOGS (insertedtable, inserterduser, insertdate) values ((select * from v$sql where first_load_time=(select max(first_load_time) from v$sql)),(SELECT USER FROM dual),null);
Da sind so viele Kinken drin, dass ich gar nicht weiß, wo ich anfangen soll.
a) wenn der Timestampwert per Dafault gestzt werden soll, dann muss das in der DDL der INSERTLOGS stehen und Du brauchst/Solltest/darfst keinen NULL-Wert übergeben. Sondern das Feld gar nicht absprechen.
b) Und statt SELECT * from v$SQL muss es sicher SELECT SQL_TEXT fron v$SQL heißen
Und dann poste bitte die DDLs der INSERTLOGS und die GRANTs auf diese Tabelle.
Und (optional) erzähl doch mal, WTF denn überhaupt der Plan hinter diesem Realisierungsversuch ist.
Grüße
Biber
Moin LordCillin
Eine Spalte kann aber nur sein, wenn Deine View V$SQL nur eine Spalte hätte.
Meine v$Sql-View gibt bei einem "Select * from v$sql" einen ganzen Sack voll Spalten zurück.
Aber vielleicht ist das ja bei der 9er Version anders <breitgrinz>.
Grüße und viel Glück
Biber
Des weiteren heißt es "FROM" und nicht "FRON", wäre mir neu wenn man so Tabellen abfragen kann.
Oh, sorry, stimmt - Du hast ja noch die Oracle 9.x - die hat ja noch keine automatische Tippfehlerkorrektur. mit der Abfrage bekomme ich nur eine Zeile/Spalte zurück
Eine Zeile kann stimmen (könnten aber auch mehrere sein, da Du nicht auf einen bestimmten USER oder einen bestimmten SERVICE abfragst) - somit kann es mehrere MIN(Timestamp)-Werte geben.Eine Spalte kann aber nur sein, wenn Deine View V$SQL nur eine Spalte hätte.
Meine v$Sql-View gibt bei einem "Select * from v$sql" einen ganzen Sack voll Spalten zurück.
Aber vielleicht ist das ja bei der 9er Version anders <breitgrinz>.
Grüße und viel Glück
Biber