메뉴 건너뛰기

조회 수 261 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
트리거 중첩트리거 
 
use shopdb;
 
 
create table orderTbl    - -구매 테이블
(orderNo Int AUTO_INCREMENT PRIMARY key,
userID VARCHAR(5),
prodName VARCHAR(5),
orderamount int
);
 
 
 
CREATE TABLE prodTbl  --물품테이블
( prodName VARCHAR(5),
    ACCOUNT int);
    
    
 create table deliverTbl(    --배송테이블 
 deliverNo INT AUTO_INCREMENT PRIMARY KEY,
 PRODNAME VARCHAR(5),
 ACCOUNT INT UNIQUE
 );  
 
 
 INSERT INTO prodTbl values('apple',100);
 INSERT INTO prodTbl values('tomat',100);
 INSERT INTO prodTbl values('pine',100);
 
 --  주문테이블에 insert 되면 상품테이블에 update가 발생하는 트리거 
 
 drop trigger if exists orderTrg;
 DELIMITER //
 CREATE TRIGGER orderTrg
    AFTER INSERT
    ON orderTbl
   FOR EACH ROW
    BEGIN
        UPDATE prodTbl SET ACCOUNT = ACCOUNT - NEW.orderamount
        where PRODNAME = new.PRODNAME;
 END //
 DELIMITER ;
 
 -- 상품테이블에 update가 발생하면 발송테이블에 insert가 발생
 
 DROP TRIGGER IF EXISTS prodTrg;
 DELIMITER //
 CREATE TRIGGER prodTrg
 AFTER UPDATE
 ON prodtbl
 FOR EACH ROW
 
 BEGIN
    DECLARE orderamount int;
    
    set orderamount = old.account - new.account;
    INSERT into deliverTbl(prodName,account) values(new.prodName,orderamount);
    
END //
DELIMITER ;
 
 
 INSERT INTO orderTbl VALUES(NULL,'JONE','apple',10);
 
 
 select * from prodTbl;
 select * from deliverTbl;
 
cs

 


List of Articles
번호 제목 날짜 조회 수
106 Create Procedure 2016.12.23 6012
105 컬럼내 특정 문자를 다른문자로 변경하고자 할때 2014.02.27 6012
104 날짜와 시간 데이터 2016.12.23 5996
103 월의 마지막 일수를 반환하는 함수입니다 2015.12.19 5996
102 외부접근 권한 주기 file 2016.12.23 5949
101 MySQL에서 사용자 권한 주기 (grant 명령어) 2017.04.12 5885
100 세자리 마다 콤마 찍기 file 2017.04.12 5879
99 MySQL 서버 데몬이 죽었을때 다시 실행하는 방법 2016.08.30 5842
98 각각의 게시판에서 제일 최근글하나씩을 모아 정렬 2016.08.30 5812
97 IN 연산자 2016.12.23 5809
96 Dump & Restore 2016.12.23 5788
95 테이블 복사, 테이블 비우기 2016.12.23 5783
94 MySQL 에서 랜덤(random)으로 레코드 읽어오기 2017.04.12 5727
93 Mysql 기본 명령어 2014.02.27 5693
92 숫자형 데이터 타입 2016.12.23 5668
91 문자형 데이터 2016.12.23 5646
90 덤프할때 한글깨짐 해결 2016.12.23 5635
89 MySQL에서 원격 IP 접속 허용하기 2017.04.12 5621
88 InnoDB, MyISAM 2016.12.23 5537
87 데이타베이스 또는 테이블 정보 2016.12.23 5534
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved