DATABASE

[MySQL] trigger로 jsp페이지 호출하기

예나부기 2022. 5. 26.

사용자들이 요청한 데이터가 있을 때

관리자에게 알람을 보내주는 API를 개발하려고 한다.

 

DB 테이블에 변동사항이 있을 때 동작해야 하므로 trigger를 쓸 것이고,

 

trigger를 통한 동작을 'jsp호출'이라는 함수 호출로 동작시키려고 한다.

 

먼저, jsp 페이지를 호출하는 사용자 정의 함수(UDF)를 생성해야한다.

 

1) lib_mysqludf_sys_64.zip 다운로드

lib_mysqludf_sys_64.zip
0.01MB

2)lib_mysqludf_sys.dll 파일을 Mysql설치 폴더 아래 plugin 폴더에 넣어준다.

*plugin 폴더 경로 확인 : show variables like 'plugin_dir';

 

3)sys_exec() 함수 생성하기

- create function sys_exec returns int soname 'lib_mysqludf_sys.dll';

 

4)생성한 함수 확인하기

- select * from mysql.func;

 

5)설치 파일 실행하기

- select sys_exec("name.exe:);

 

트리거를 사용하여 특정 테이블에 업데이트 되었을 때 jsp 페이지를 호출

delimiter //
create trigger [생성할 trigger 이름]
after update on [trigger를 걸 테이블 이름]
for each row
begin 
declare result int;
set result = (select sys_exec("curl -v hrrp://localhost/testURL/server/test.jsp");
end; //

-delimiter는 쿼리가 끝나는 표시를 기존 ;에서 //로 변경하도록 도와준다.

(우리가 쓸 쿼리에 ;가 있기 때문에)

 

- 해당 트리거를 사용한다면 호출이 성공했을 때, result 값으로 0이 내려온다.

 

여기에, log테이블에 변경 사항을 저장하는 부분을 추가해보자!

트리거를 사용하여 변경 내역 log 테이블에 저장하기

1)먼저 log 테이블을 생성한다.

2)만약 insert, update문에 걸려있는 trigger라면 변경된 컬럼을 가져오고 싶다면 NEW.컬럼명 을 통해 데이터를 가져온다.

* delete, update문에 걸려있는 trigger에서 변경 전 데이터를 가져오고 싶다면? OLD.컬럼명!

create trigger [생성할 trigger 이름]
after insert on [trigger를 걸 테이블 이름]
 for each row
 begin
declare result int;
set result = (select sys_exec("curl -v http://호출할 JSP 페이지.jsp"));
insert into log values(NEW.컬럼명1, NEW.컬럼명2, NEW.컬럼명3);
 end;
 //

 

댓글