-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreate.sql
176 lines (152 loc) · 7.24 KB
/
create.sql
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
#초기 데이터베이스를 생성하고 데이터를 삽입하는 SQL 스크립트: create.sql
use DB2022Team08
#회원에 대한 정보를 저장하는 회원 table 생성
CREATE TABLE DB2022_회원 (
전화번호 VARCHAR(30),
회원이름 VARCHAR(10) NOT NULL,
구매금액 INT DEFAULT 0,
회원등급 VARCHAR(10) DEFAULT 'bronze',
PRIMARY KEY(전화번호)
);
/*
구매금액 회원등급
0~99,999원 : bronze
100,000~499,999 : silver
500,000~999,999 : gold
1,000,000~ : vip
*/
#영수증에 대한 정보를저장하는 영수증 테이블 생성
CREATE TABLE DB2022_영수증 (
영수증번호 VARCHAR(10),
전화번호 VARCHAR(30),
총결제금액 INT DEFAULT 0,
판매일자 DATE,
PRIMARY KEY(영수증번호),
FOREIGN KEY(전화번호) REFERENCES DB2022_회원(전화번호)
);
#상품에 대한 정보를 저장하는 상품 테이블 생성
CREATE TABLE DB2022_상품 (
상품번호 VARCHAR(10),
상품카테고리 VARCHAR(30),
상품명 VARCHAR(30),
상품사이즈 VARCHAR(10),
판매가격 INT,
제조업체 VARCHAR(20),
재고량 INT,
PRIMARY KEY(상품번호)
);
#발주에 대한 정보를 저장하는 발주 테이블 생성
CREATE TABLE DB2022_발주 (
발주상품번호 VARCHAR(10),
발주상품가격 INT,
발주날짜 DATE,
발주시간 TIME,
발주수량 INT,
담당자이름 VARCHAR(20),
제조업체전화번호 VARCHAR(20),
PRIMARY KEY(발주날짜, 발주시간),
FOREIGN KEY(발주상품번호) REFERENCES DB2022_상품(상품번호)
);
#영수증 번호에 따라 구매한 한 품목의 정보를 저장하는 품목 테이블 생성
CREATE TABLE DB2022_품목 (
영수증번호 VARCHAR(10),
상품번호 VARCHAR(10),
수량 INT,
가격 INT,
PRIMARY key (영수증번호,상품번호),
foreign key (영수증번호) references DB2022_영수증(영수증번호),
foreign key (상품번호) references DB2022_상품(상품번호)
);
#하나의 영수증에 대해 최대 하나의 리뷰 정보를 저장하는 리뷰 테이블 생성
CREATE TABLE DB2022_리뷰 (
영수증번호 VARCHAR(10),
방문일자 date,
작성자 VARCHAR(30),
평점 int,
작성일자 date,
PRIMARY key (영수증번호),
foreign key (작성자) references DB2022_회원(전화번호)
);
#고객 사용자에게 상품 테이블 중 상품번호, 재고량 등의 정보는 숨기고 상품명, 상품 사이즈, 판매가격만 공개하는 뷰 생성
CREATE VIEW DB2022_PRICE_VIEW AS
SELECT 상품명, 상품사이즈, 판매가격 FROM DB2022_상품;
#리뷰의 익명성 보장을 위해 평점과 작성일자만 공개하는 뷰 생성
CREATE VIEW DB2022_REVIEW_VIEW AS
SELECT 평점, 작성일자 FROM DB2022_리뷰;
#회원 삭제, 정보 수정, 검색 시 '전화번호'를 통해 검색하므로 index로 지정
CREATE INDEX member_phone ON DB2022_회원 (전화번호);
#리뷰 등록 시 영수증 번호를 통해 회원이 구매한 영수증이 맞는지 확인하므로 index로 지정
CREATE INDEX receit_num ON DB2022_영수증 (영수증번호);
#내가 쓴 리뷰 조회시 전화번호를 통한 검색이 이루어지므로 index로 지정
CREATE INDEX review_phone ON DB2022_리뷰 (작성자);
#리뷰 삭제, 정보 수정, 검색 시 '영수증 번호'를 통해 검색하므로 index로 지정
CREATE INDEX receit_num_review ON DB2022_리뷰 (영수증번호);
#발주 삭제, 수정, 검색 시 '발주 날짜'를 통해 검색하므로 index로 지정
CREATE INDEX orderdate ON DB2022_발주 (발주날짜);
/*
인덱스 삭제 방법 :
ALTER TABLE DB2022_회원 DROP INDEX member_phone;
ALTER TABLE DB2022_영수증 DROP INDEX receit_num;
ALTER TABLE DB2022_리뷰 DROP INDEX review_phone;
ALTER TABLE DB2022_리뷰 DROP INDEX receit_num_review;
ALTER TABLE DB2022_발주 DROP INDEX orderdate;
*/
#회원 table에 tuples 삽입
INSERT INTO DB2022_회원 VALUES
('010-4024-2434', '춘식이', 64000, 'bronze'),
('010-1234-1254', '라이언', 38500, 'bronze'),
('010-1245-2356', '어피치', 17500, 'bronze'),
('010-1233-4566', '프로도', 295000, 'silver'),
('010-4566-4566', '무지', 295000, 'silver'),
('010-7899-4566', '콘', 295000, 'silver'),
('010-7410-4566', '네오', 695000, 'gold'),
('010-1245-4578', '튜브', 1009000, 'vip');
#영수증 table에 tuples 삽입
#회원 table의 '전화번호'를 참조하므로 회원 table보다 나중에 삽입
INSERT INTO DB2022_영수증 VALUES
('001', '010-4024-2434', 37700, '2021-05-25'),
('002', '010-1245-2356', 7500, '2022-05-18'),
('003', '010-4566-4566', 2700, '2022-03-02'),
('004', '010-7899-4566', 15000, '2022-05-15'),
('005', '010-7410-4566', 16500, '2022-05-08'),
('006', '010-1245-4578', 509000, '2022-04-17');
#상품 table에 tuples 삽입
INSERT INTO DB2022_상품 VALUES
("001", "맥주", "테라캔","500ml" , 2350, "하이트진로", 300),
("002", "맥주", "테라병","1600ml", 6100, "하이트진로", 50),
("003", "맥주", "칭다오", "500ml" , 2500, "TSINGDAO BREWERY", 200),
("004", "소주", "처음처럼병", "360ml", 1800, "롯데칠성", 170),
("005", "소주", "처음처럼페트", "640ml", 3000, "롯데칠성", 140),
("006", "소주", "참이슬", "360ml", 1650, "하이트진로", 70),
("007", "막걸리", "국순당생막걸리", "750ml", 1800, "국순당", 5),
("008", "양주", "조니워커블루라벨", "750ml", 250000, "조니워커", 15);
#발주 table에 tuples 삽입
#회원 table의 상품명 attribute를 참조하고 있으니까 회원 table보다 나중에 INSERT
INSERT INTO DB2022_발주 VALUES
("001", 1900, "2022-05-03", "15:13:33", 90, "김책임", "02-4321-9876"),
("002", 5100, "2022-05-03", "15:13:35", 80, "김책임", "02-4321-9876"),
("003", 2000, "2022-05-09", "19:18:49", 70, "이담당", "031-456-789"),
("004", 1200, "2022-05-13", "09:05:01", 150, "박사원", "02-4141-4141"),
("005", 2400, "2022-05-13", "09:06:01", 50, "박사원", "02-4141-4141"),
("006", 1000, "2022-05-16", "13:45:25", 120, "최대리", "032-1478-5236"),
("007", 1100, "2022-05-17", "18:00:00", 30, "송주임", "051-7410-7410"),
("008", 150000, "2022-05-19", "11:50:40", 10, "Heather", "02-0519-0519");
#품목 table에 tuples 삽입
#상품번호, 영수증번호 attribute를 참조하고 있으니까 상품, 영수증 table보다 나중에 INSERT
INSERT INTO DB2022_품목 VALUES
('001', '002', 5, 30500),
('001', '004', 4, 7200),
('002', '003', 3, 7500),
('003', '001', 2, 2700),
('004', '005', 5, 15000),
('005', '006', 10, 16500),
('006', '007', 5, 9000),
('006', '008', 2, 500000);
#리뷰 table에 tuples 삽입
#영수증번호 attribute를 참조하고 있으니까 영수증 table보다 나중에 INSERT
INSERT INTO DB2022_리뷰 VALUES
('001','2021-05-25','010-4024-2434',5,'2022-01-02'),
('002','2022-05-18','010-4024-2434',5,'2022-02-02'),
('003','2022-03-02','010-1234-1254',3,'2022-03-02'),
('004','2022-05-15','010-7899-4566',5,'2022-04-02'),
('005','2022-04-17','010-7410-4566',5,'2022-05-02');