MySQL Trigger löst nicht aus bei Hibernate Update

OnDemand

Top Contributor
Hallo zusammen,

hab einen Trigger "After Update" auf eine double Spalte, welche nicht auslöst, wenn das Programm den entsprechenden Wert updated.

Wenn ich den Wert in der DB manuell ändere, löst der Trigger aus. Nur wenn Hibernate das Update auf den Wert macht, passiert nix.

Hier der Trigger:

Code:
create definer =user@`%` trigger update_price
after UPDATE on prices
for each row
BEGIN
  IF NEW.vk_price_netto <> OLD.vk_price_netto THEN
    insert into update_log (product_id, updated_field, old_value, new_value) values (NEW.id, 'PPRC', OLD.vk_price_netto, NEW.vk_price_netto);
  END IF;
END;
 

OnDemand

Top Contributor
Huhu, mir fiel jetzt auf, dass der Trigger scheinbar doch irgendwann aufgerufen wird. Meine update table hat nun alles drin.

Die Änderungen werden sofort geschrieben, das sehe ich. Aber möglicherweise wird erst später geflushed/commited?
nutze Spring Boot, weiß da nicht genau, wie es wann was macht. Wenn ich mit repository.saveAndFlush() arbeite, wird es auch nicht sofort getriggered. Hast du noch eine Idee?
 

OnDemand

Top Contributor
Der Trigger hat doch nicht ausgelöst. Ich habe update prices set price =0 gemacht um die preise für testzwecke zu nullen. Dieses Update hat den Trigger ausgelöst, nicht aber das Update von Hibernate :(
 

OnDemand

Top Contributor
Nein ist 0 als 0,00

Hab mir jetzt nochmal, die Queries nochmal genauer angesehen:
Hibernate macht ein delete und dann ein insert, dann kein Wunder. Aber warum macht es nicht ein Update? So kann ich mir nicht triggern, was old und was new ist :(
Liegt vermutlich an den Relations der Entities oder?

Kann da einen Workaround machen, aber ein Update wäre mir schon lieber
 

OnDemand

Top Contributor
Wie folgt:

Produkt.java:
@OneToMany(orphanRemoval = true, cascade = {CascadeType.ALL})
@LazyCollection(LazyCollectionOption.FALSE)
@JoinColumn(name = "product_id")
private List<Preis> productsPreise = new ArrayList<>();

auf der Preis-Seite gibts keine Referenz auf das Produkt. Jeweils Getter Setter, Konstruktor etc, alles da
 

OnDemand

Top Contributor
PreisEntity hat nur ek und vk Preis und die ID:

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private int id;

so sieht auch die ID im Produkt aus
 

mihe7

Top Contributor
Wie aktualisierst Du denn den Preis? Rufst Du einen Setter auf der PreisEntity auf oder setzt Du ein Objekt in productsPreise-List? Falls letzteres: wo kommt das PreisEntity-Objekt her?
 

mihe7

Top Contributor
Das Problem wird sein, dass das Preis-Objekt zum Zeitpunkt des Speicherns noch transient (neu) und damit dem EntityManager noch unbekannt ist. Der geht dann von einer neuen Entity aus, entfernt die alte und fügt die neue ein. Du müsstest Dir die Preis-Entity vorher aus der DB holen und ändern oder das neue Objekt mergen und das gemergte Objekt verwenden.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Kirby.exe Error bei Trigger Datenbankprogrammierung 5
Kirby.exe Trigger Datenbankprogrammierung 2
M Sql Trigger Datenbankprogrammierung 7
Dimax MySQL Trigger für eine Spalte Datenbankprogrammierung 5
D Trigger Datenbankprogrammierung 1
J SQL-Statement Trigger zeigt keine Wikrung PL/SQL Datenbankprogrammierung 2
P Trigger in DB Datenbankprogrammierung 1
T f:event preRenderView Trigger wird nicht ausgeführt Datenbankprogrammierung 4
M Oracle Trigger Datenbankprogrammierung 3
D Mit Trigger Tupel löschen verhindern Datenbankprogrammierung 3
K Trigger Datenbankprogrammierung 9
S Oracle Trigger Datenbankprogrammierung 5
E Trigger ??? Datenbankprogrammierung 5
Landei Trigger in MS-SQL Datenbankprogrammierung 3
M Datenbank mit trigger Datenbankprogrammierung 17
P DatenBank trigger Datenbankprogrammierung 7
T MySQL: Trigger und Prozeduren erstellen Datenbankprogrammierung 4
L UPDATE löst Exception aus Datenbankprogrammierung 6
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
D 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
M 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
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

Ähnliche Java Themen

Neue Themen


Oben