triggerfunction funzt nicht

Status
Nicht offen für weitere Antworten.

noisebreath

Bekanntes Mitglied
hi hab ne triggerfunction geschrieben, aber die funzt nicht. Vielleicht sieht ja jemand von euch woran es liegt:

Code:
CREATE OR REPLACE FUNCTION calculateoverallscore() RETURNS TRIGGER AS $testswherechanged$
DECLARE
	totalscore numeric;

BEGIN
	IF (OLD.testid != 8)
				
		IF(SELECT COUNT(*) FROM resultsview WHERE testperiodid = OLD.testperiodid AND talentid=OLD.talentid AND testid in ('2','3','4','5','7') = 5) THEN

			FOR values IN (SELECT testid, value FROM results WHERE testperiodid = OLD.testperiodid AND talentid = OLD.talentid ORDER BY testid ASC) LOOP
				IF(values.testid = 2) THEN
				totalscore := values.value * 17.29
				END IF;
				IF(values.testid = 3) THEN
				totalscore := totalscore + values.value * 9.43
				END IF;
				IF(values.testid = 4) THEN
				totalscore := totalscore + values.value * 4.11
				END IF;
				IF(values.testid = 5) THEN
				totalscore := totalscore + values.value * 2.41
				END IF;
				IF(values.testid = 7) THEN
				totalscore := totalscore + values.value,
				END IF;
					
					
			END LOOP;
			
			totalscore := 1/totalscore*10000
			INSERT INTO results (value,testid,testperiodid,talentid,changed,created) VALUES(totalscore,8,OLD.testperiodid,OLD.talentid,current_timestamp,current_timestamp);

		END IF;
		
	END IF;
END;
$testswherechanged$ LANGUAGE plpgsql;
CREATE TRIGGER testswherechanged AFTER INSERT ON results FOR EACH ROW EXECUTE PROCEDURE calculateoverallscore();

Fehlermeldung beim ausführen:

ERROR: syntax error at or near "IF"
LINE 1: SELECT ( $1 != 8) IF(SELECT COUNT(*) FROM resultsview WHER...
^
QUERY: SELECT ( $1 != 8) IF(SELECT COUNT(*) FROM resultsview WHERE testperiodid = $2 AND talentid= $3 AND testid in ('2','3','4','5','7') = 5)
CONTEXT: SQL statement in PL/PgSQL function "calculateoverallscore" near line 7

********** Fehler **********

ERROR: syntax error at or near "IF"
SQL Status:42601

bitte um hilfe :(
 
S

SlaterB

Gast
zu einem IF gehört doch immer noch ein THEN? zwischen den beiden IF in Zeile 7 bis 9 ist keines

warum so kompliziert aber die einfachste Grundsyntax noch nicht korrekt

immer möglichst einfach anfangen oder zumindest wenn ein Fehler kommt,
dann erstmal alles unnötige raus und

IF true THEN
hello world

oder ähnlich testen,
von PL SQL weiß ich nix ;)
 

noisebreath

Bekanntes Mitglied
danke dass hab ich übersehen ^^

jetzt passt das aber er schmeisst mir eine weitere meldung :


ERROR: loop variable of loop over rows must be a record or row variable or list of scalar variables at or near "LOOP"
LINE 13: ...riodid AND talentid = OLD.talentid ORDER BY testid ASC) LOOP
^

********** Fehler **********

ERROR: loop variable of loop over rows must be a record or row variable or list of scalar variables at or near "LOOP"
SQL Status:42601
Zeichen:450
 

noisebreath

Bekanntes Mitglied
hab übrigens rausgefunden dass bei inserts die variablen nicht old. sind sondern dann mit new. angesprochen werden muessen:

Code:
CREATE OR REPLACE FUNCTION calculateoverallscore() RETURNS TRIGGER AS $testswherechanged$
DECLARE
	totalscore numeric;

BEGIN
	IF (new.testid != 8) THEN
				
		IF(SELECT COUNT(*) FROM resultsview WHERE testperiodid = new.testperiodid AND talentid=new.talentid AND testid in ('2','3','4','5','7') = 5) THEN

			FOR values IN (SELECT testid, value FROM results WHERE testperiodid = new.testperiodid AND talentid = new.talentid ORDER BY testid ASC) LOOP
				IF(values.testid = 2) THEN
				totalscore := values.value * 17.29
				END IF;
				IF(values.testid = 3) THEN
				totalscore := totalscore + values.value * 9.43
				END IF;
				IF(values.testid = 4) THEN
				totalscore := totalscore + values.value * 4.11
				END IF;
				IF(values.testid = 5) THEN
				totalscore := totalscore + values.value * 2.41
				END IF;
				IF(values.testid = 7) THEN
				totalscore := totalscore + values.value,
				END IF;
					
					
			END LOOP;
			
			totalscore := 1/totalscore*10000
			INSERT INTO results (value,testid,testperiodid,talentid,changed,created) VALUES(totalscore,8,new.testperiodid,new.talentid,current_timestamp,current_timestamp);

		END IF;
		
	END IF;
END;
$testswherechanged$ LANGUAGE plpgsql;
CREATE TRIGGER testswherechanged AFTER INSERT ON results FOR EACH ROW EXECUTE PROCEDURE calculateoverallscore();

aber was die fehlermeldung anbelangt hat sich leider nichts geändert :-/ hab ich was bei der loopsyntax falsch verstanden?
 
S

SlaterB

Gast
kann es sein, dass VALUES gerade ein Schlüsselwort in SQL ist? Groß/ Kleinschreibung muss ja niemanden beeindrucken,
versuche bitte einen der 10^30 anderen möglichen Variablennamen ;)
 

noisebreath

Bekanntes Mitglied
vollkommen korrekt:

Code:
DECLARE
 totalscore numeric;
 currentrow RECORD;
 counter INTEGER;
 
BEGIN
 IF (NEW.testid != 8) THEN
    SELECT INTO counter COUNT(*) FROM resultsview WHERE testperiodid = NEW.testperiodid AND talentid=NEW.talentid AND testid in ('2','3','4','5','7');
  IF(counter = 5) THEN
 
   FOR currentrow IN (SELECT testid, value FROM results WHERE testperiodid = NEW.testperiodid AND talentid = NEW.talentid ORDER BY testid ASC) LOOP
    IF(currentrow.testid = 2) THEN
     totalscore := currentrow.value * 17.29;
    ELSEIF(currentrow.testid = 3) THEN
     totalscore := totalscore + currentrow.value * 9.43;
    ELSEIF(currentrow.testid = 4) THEN
     totalscore := totalscore + currentrow.value * 4.11;
    ELSEIF(currentrow.testid = 5) THEN
     totalscore := totalscore + currentrow.value * 2.41;
    ELSEIF(currentrow.testid = 7) THEN
     totalscore := totalscore + currentrow.value;
    END IF;
   END LOOP;
   
   totalscore := 1/totalscore*10000;
   INSERT INTO results (value,testid,testperiodid,talentid,changed,created) VALUES (totalscore,8,NEW.testperiodid,NEW.talentid,current_timestamp,current_timestamp);
   RETURN NULL;
  ELSE
   RETURN NULL;
  END IF;
 ELSE
  RETURN NULL;
 END IF;
 
END;
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M insert befehl funzt nicht!wo ist der fehler? Datenbankprogrammierung 5
R Windows: funzt -> Linux: Exceptions Datenbankprogrammierung 4
T insert funzt net richtig Datenbankprogrammierung 6
R wer kennt Sage - KHK ? ODBC funzt nicht ? Datenbankprogrammierung 9
S mysql funzt nicht Datenbankprogrammierung 2
krgewb Hibernate: Fremdschlüssel wird nicht erzeugt Datenbankprogrammierung 2
W MySQL-Connector funktioniert nicht über WLAN -> MacOS Datenbankprogrammierung 10
M Meine Datenbank lässt sich mit meiner Methode nicht ändern Datenbankprogrammierung 1
P Reicht finally nicht um DB connections zu schließen in (altem) Java? Datenbankprogrammierung 4
G JOIN COLUMN wird nicht genommen Datenbankprogrammierung 2
Maxim6394 JPA / EclipseLink - n:m Beziehung wird nicht aktualisiert Datenbankprogrammierung 0
J SQLite Abfrage fehlerhaft - komme nicht weiter - please help. Datenbankprogrammierung 3
D Ich möchte dass ich nachdem man den Kommentar geschrieben hat den Kommentar in den Tabelle Bestellübersicht geschbeichert wird klappt nicht bei mir Datenbankprogrammierung 2
MJannek Datenbank Zugraff nach Umwandlung in .jar-Datei nicht mehr möglich Datenbankprogrammierung 4
Auf MySql Datenbank zugreifen funktioniert nicht Datenbankprogrammierung 8
A Java DB Server lässt sich nicht starten Datenbankprogrammierung 3
B SQlite Datenbank, trotz Statements wurden nicht alle Zeilen erzeugt? Datenbankprogrammierung 35
T Datenzeilen werden nicht gelöscht Datenbankprogrammierung 6
Warum funktioniert MySQL nicht Datenbankprogrammierung 8
S Das printen der Ausgabe des Oracle-SQL-Statements in der Java-Eclipse-Konsole funktioniert nicht Datenbankprogrammierung 6
S Datenbankprogrammierung in Java unter NetBeans 12 funktioniert nicht! Datenbankprogrammierung 1
pkm PostgreSQL Kann mit mybatis einen Parameter für eine postgreSQL-Abfrage nicht übergeben. Datenbankprogrammierung 5
Davee SQLite SQLite Datenbank lässt sich nicht auf anderen PCs öffnen Datenbankprogrammierung 8
Watsoon Treiber wird in Intellij nicht geladen Datenbankprogrammierung 2
Kirby.exe PreparedStatement wird nicht ausgeführt Datenbankprogrammierung 5
rafi072001 MicroServices EurekaClient findet anderern EurekaClient nicht Datenbankprogrammierung 1
D JPA gleiche methode funktioniert an einer Stelle, an der anderen nicht Datenbankprogrammierung 3
Z Datenbank Choicebox wird nicht befüllt Datenbankprogrammierung 15
pkm PostgreSQL Auf eine Spalte kann aus einem Teil der SQL-Aussage nicht zugegriffen werden Datenbankprogrammierung 3
G MySQL JDBC Metadaten auslesen aus .accdb -> Primärschlüssel manchmal erkannt manchmal nicht Datenbankprogrammierung 3
C MySQL SQL Statement wir nicht ausgeführt Datenbankprogrammierung 11
N Sqlite DB mit Java wird auf Linuxsystem nicht gefunden Datenbankprogrammierung 9
pkm Tomcat Classloader findet bei JPA-Persistierung die Persistence Unit nicht. Datenbankprogrammierung 11
F Tabellen automatisch erstellen wenn sie nicht existieren Datenbankprogrammierung 6
J Netbeans 11 und Eclipse JPA 2.5 Entity wird nicht gefunden Datenbankprogrammierung 4
J Java fügt Datensätze ein aber diese werden nicht richtig abgefragt Datenbankprogrammierung 3
J Firebase KeepSynced funktioniert nicht Datenbankprogrammierung 0
OnDemand MySQL Trigger löst nicht aus bei Hibernate Update Datenbankprogrammierung 12
R HSQLDB ResultSet update aktualisiert DB, aber nicht das ResultSet Datenbankprogrammierung 2
platofan23 MySQL Java Programm findet Treiber für mySQL auf Debian-Server nicht? Datenbankprogrammierung 11
B MySQL Data Tools Plattform - "Database Connections" findet den Treiber nicht Datenbankprogrammierung 1
OnDemand One to Many bekomm es nicht hin Datenbankprogrammierung 7
L SQL-Statement INSERT INTO ON DUPLICATE KEY UPDATE funktioniert nicht Datenbankprogrammierung 5
OnDemand Update auf Mysql läuft nicht durch Datenbankprogrammierung 30
R jdbc-Zugriff Nicht erlaubt ? Datenbankprogrammierung 16
F H2 ObjectOptimisticLockingFailureException wird nicht geworfen Datenbankprogrammierung 0
R findet Derby.DB nicht !? Datenbankprogrammierung 5
I Datenbankverbindung Oracle DB klappt nicht - getConnection returned null Datenbankprogrammierung 8
X SQLite SQLite Programm beendet/führt nicht weiter aus Datenbankprogrammierung 12
P LDAP: Daten eintragen funktioniert nicht Datenbankprogrammierung 7
Ananaskirsche Datenbanktreiber kann nicht geladen werden Datenbankprogrammierung 2
S sun.jdbc.odbc.JdbcOdbcDriver wird nicht gefunden Datenbankprogrammierung 2
U Kann die Tabellen nicht finden Datenbankprogrammierung 0
M Java Datenbankanbindung funktioniert nicht Datenbankprogrammierung 4
C MYSQL kann wert nicht eintragen Datenbankprogrammierung 3
J Verbindung zu Derby Datenbank funktioniert nicht Datenbankprogrammierung 14
S MySQL MySQL will einfach nicht, bitte um Rat Datenbankprogrammierung 4
E Warum funktioniert das Erzeugen einer View nicht? Datenbankprogrammierung 1
E Warum kann mein SQL-File nicht in DB2 ausgeführt werden? Datenbankprogrammierung 1
M JDBC Tabellen mit Boolean Spalten können nicht erstellt werden. DB Updaten - wie? Datenbankprogrammierung 6
T Tabellen von nicht mehr vorhandenen Entities werden generiert Datenbankprogrammierung 0
OnDemand Update table SET will nicht Datenbankprogrammierung 9
M DB-Zugriff funktioniert nach JAR-Erstellung nicht mehr Datenbankprogrammierung 3
J SQL-Statement Meine insert befehle funktionieren nicht und ich weiß nicht wo der fehler liegt Datenbankprogrammierung 5
S MySQL Speicher wird nicht freigegeben bei Datenbankabfragen Datenbankprogrammierung 6
L SQL Statement mit Switch-Case funktioniert nicht Datenbankprogrammierung 6
D MySQL Eingabe wird nicht übernommen... Datenbankprogrammierung 11
H Derby: SYSCS_UTIL.SYSCS_EXPORT_QUERY mit String Abfrage in wehre-Klausel nicht möglich Datenbankprogrammierung 3
F sun.jdbc.odbc.jdbcodbcdriver wird nicht gefuden Datenbankprogrammierung 3
L JTable-DB: Letzter wert wird nicht angezeigt. Datenbankprogrammierung 0
I Datenbank Verbindung geht nicht Datenbankprogrammierung 2
L MySQL App/Java Zugriff auf Mysql-DB funktioniert nicht Datenbankprogrammierung 1
I Kann nicht mit iiS DB Verbinden Datenbankprogrammierung 1
S Verbindungsaufbau zu MySql Datenbank nicht möglich Datenbankprogrammierung 3
D [xBaseJ] Datei kann nicht geöffnet werden Datenbankprogrammierung 2
N JDBC: rollback() bei Exception geht nicht!? Datenbankprogrammierung 1
K Datenbank wird bei Programmstart als .jar nicht mehr befüllt Datenbankprogrammierung 12
R Datenbankverbindung kann nicht hergestellt werden Datenbankprogrammierung 8
M Oracle Bekomme fertiges Tool nicht ans Laufen Datenbankprogrammierung 3
V Test H2-DB löscht nicht die IDs Datenbankprogrammierung 0
P PostgreSQL Java-Anwendung zählt rollbacks nicht Datenbankprogrammierung 0
M Finde einen eifachen Befehl nicht Datenbankprogrammierung 4
T MySQL Datetime wird auf Sekunden gerundet, soll es aber nicht Datenbankprogrammierung 2
P MySQL jpmdbc: Kann lesen aber nicht schreiben? Datenbankprogrammierung 3
1 MySQL Verbindung mit localhost als IP funktioniert, aber mit normaler IP nicht Datenbankprogrammierung 2
M Derby/JavaDB Neu geschriebener Eintrag per UPDATE lässt sich nicht unmittelbar abrufen Datenbankprogrammierung 2
J Datenbankeintag eines Warenkorbes funktioniert nicht Datenbankprogrammierung 4
AMStyles Kann Wert nicht speichern (MAX VALUE) Datenbankprogrammierung 9
M MySQL INSERT will einfach nicht funktionieren Datenbankprogrammierung 9
A Nach Export mysql Verbindung zur Datenbank nicht möglich, was tun? Datenbankprogrammierung 7
T SQL-Statement case when then klappt nicht Datenbankprogrammierung 4
B DB2 Hibernate findet Datenbank nicht Datenbankprogrammierung 18
J JDBC in Library|"Treiber konnte nicht geladen werden"" Datenbankprogrammierung 2
D MySQL Treiber konnte nicht geladen werden Datenbankprogrammierung 3
P JSF + H2 + TomEE + Hibernate/JPA Datenbank wird nicht angelegt Datenbankprogrammierung 3
C Db4o speichert verschachtelte Objekte nicht vollständig Datenbankprogrammierung 8
P SQL-Statement "Top 1" oder "limit" funktioniert nicht Datenbankprogrammierung 12
C Programm wird nach DB-Eintrag nicht weitergeführt Datenbankprogrammierung 5
R sqlite UPDATE wirkt nicht aus Java Datenbankprogrammierung 7
crashfinger jdbc-connection mit jre7 funktioniert nicht Datenbankprogrammierung 5

Ähnliche Java Themen

Neue Themen


Oben