A PL/Java egy olyan addon PostgreSQL-hez, melynek segítségével Java-ban írhatunk triggereket az adatbázisunkhoz.
A triggerek tárolt eljárások az adatbázisban, melyek adott esemény előtt vagy után futnak le (az esemény lehet valamelyik táblán insert, update vagy delete query). Különböző adatbázisok nagyon eltérő módon szemlélhetik a triggereket, pl. MySQL-ben a trigger egy SQL lekérdezés, postgresql-ben egy valamilyen programnyelven megírt függvény. Triggereket elsősorban akkor érdemes használni, ha több alkalmazás használja ugyanazt az adatbázist. Ilyenkor az adatok konzisztenciájára, "szabályosságára" minden alkalmazásban külön-külön kellene figyelnünk, így jelentős mennyiségű duplikált kód keletkezik, de ha ugyanezt az alkalmazások alatt, az adatbázisban oldjuk meg triggerekkel, akkor nincs ilyen probléma.
A PL/Java úgy működik, hogy az eljárásokat java-ban mint statikus metódusokat írjuk meg, majd ezeket rendeljük hozzá az eseményekhez. Sajnos a dolog nem ennyire egyszerű, nekem legalább 6 órámba telt mindennel együtt, amíg ubuntun beállítottam egy hello world szintű triggert.
A triggerek tárolt eljárások az adatbázisban, melyek adott esemény előtt vagy után futnak le (az esemény lehet valamelyik táblán insert, update vagy delete query). Különböző adatbázisok nagyon eltérő módon szemlélhetik a triggereket, pl. MySQL-ben a trigger egy SQL lekérdezés, postgresql-ben egy valamilyen programnyelven megírt függvény. Triggereket elsősorban akkor érdemes használni, ha több alkalmazás használja ugyanazt az adatbázist. Ilyenkor az adatok konzisztenciájára, "szabályosságára" minden alkalmazásban külön-külön kellene figyelnünk, így jelentős mennyiségű duplikált kód keletkezik, de ha ugyanezt az alkalmazások alatt, az adatbázisban oldjuk meg triggerekkel, akkor nincs ilyen probléma.
A PL/Java úgy működik, hogy az eljárásokat java-ban mint statikus metódusokat írjuk meg, majd ezeket rendeljük hozzá az eseményekhez. Sajnos a dolog nem ennyire egyszerű, nekem legalább 6 órámba telt mindennel együtt, amíg ubuntun beállítottam egy hello world szintű triggert.

