사용자들이 요청한 데이터가 있을 때
관리자에게 알람을 보내주는 API를 개발하려고 한다.
DB 테이블에 변동사항이 있을 때 동작해야 하므로 trigger를 쓸 것이고,
trigger를 통한 동작을 'jsp호출'이라는 함수 호출로 동작시키려고 한다.
먼저, jsp 페이지를 호출하는 사용자 정의 함수(UDF)를 생성해야한다.
1) lib_mysqludf_sys_64.zip 다운로드
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;
//
'DATABASE' 카테고리의 다른 글
MariaDB 손상 복구 관련 정리 자료(2) -MYISAM (0) | 2022.09.27 |
---|---|
MariaDB 손상 복구 관련 정리 자료(1) -InnoDB (0) | 2022.09.27 |
[Database] where 1=2, where 1=1을 사용하여 테이블 복사하기 (0) | 2022.05.23 |
[MySQL] MySQL Explain 실행계획 사용법 및 분석 (0) | 2022.05.03 |
[MSSQL] 엑셀 데이터 가져오기와 에러 해결하기 (0) | 2022.04.22 |
댓글