-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathDatabse_querries.txt
369 lines (309 loc) · 10.5 KB
/
Databse_querries.txt
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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
CREATE TABLE patient(
pid int,
fname varchar(20) not null,
lname varchar(20),
gender varchar(6) not null,
dob date not null,
blood_group varchar(3),
doc_id int,
HNo varchar(10),
street varchar(20),
city varchar(16),
state varchar(20),
email varchar(30),
Primary Key(pid));
CREATE TABLE Employee(
empid int,
fname varchar(20) not null,
mname varchar(20),
lname varchar(20),
gender varchar(6) not null,
emptype varchar(20) not null,
Hno varchar(10),
street varchar(20),
city varchar(20),
state varchar(20),
date_of_joining date,
email varchar(30),
deptid int,
since date,
date_of_birth date,
PRIMARY key(empid));
CREATE TABLE department(
deptid int,
dname varchar(20) not null,
dept_headid int(10),
PRIMARY key(deptid));
CREATE table salary(
etype varchar(20),
salary float(20,2),
PRIMARY key(etype));
CREATE TABLE nurse_assigned(
nid int,
countpatient int,
PRIMARY KEY(nid),
FOREIGN KEY(nid) REFERENCES employee(empid));
CREATE TABLE out_patient(
pid int,
arrival_date date,
disease varchar(40),
PRIMARY key(pid,arrival_date),
FOREIGN KEY(pid) REFERENCES patient(pid));
CREATE TABLE room(
rid int,
roomtype varchar(20),
PRIMARY key(rid));
CREATE TABLE in_patient(
pid int,
nid int,
rid int,
arrival_date date,
discharge_date date,
disease varchar(40),
primary key(pid,arrival_date),
FOREIGN key(pid) REFERENCES patient(pid),
FOREIGN KEY(nid) REFERENCES employee(empid),
FOREIGN key(rid) REFERENCES room(rid));
CREATE TABLE room_cost(
roomtype varchar(20),
rcost int,
PRIMARY KEY(rtype));
CREATE TABLE relative(
pid int,
rname varchar(30),
rtype varchar(30),
pno varchar(11),
PRIMARY key(pid));
CREATE TABLE test(
tid int,
tname varchar(20),
tcost float(10,2),
primary KEY(tid));
CREATE TABLE hadtest(
pid int,
tid int,
testdate date,
PRIMARY KEY(pid,tid,testdate),
FOREIGN KEY(pid) REFERENCES patient(pid),
FOREIGN key(tid) REFERENCES test(tid));
CREATE TABLE medicine(
mid int,
mname varchar(40) not null,
mcost float(20,2),
PRIMARY key(mid));
CREATE TABLE had_medicine(
pid int,
mid int,
med_date date,
qty int,
PRIMARY KEY(pid,mid,med_date),
FOREIGN KEY(pid) REFERENCES patient(pid),
FOREIGN KEY(mid) REFERENCES medicine(mid));
CREATE TABLE pt_phone(
pid int,
phoneno varchar(10),
PRIMARY KEY(pid,phoneno),
FOREIGN KEY(pid) REFERENCES patient(pid));
CREATE TABLE emp_phone(
empid int,
phoneno varchar(10),
PRIMARY KEY(empid,phoneno));
CREATE TABLE bill(
pid int,
mcost float(20,2),
tcost float(20,2),
roomcharges float(20,2),
othercharges float(20,2),
billdate date,
PRIMARY KEY(pid,billdate));
CREATE TABLE employee_inactive(
empid int,
fname varchar(20) not null,
mname varchar(20),
lname varchar(20),
gender varchar(6) not null,
emptype varchar(20) not null,
Hno varchar(10),
street varchar(20),
city varchar(20),
state varchar(20),
date_of_joining date,
date_of_leaving date,
email varchar(30),
PRIMARY key(empid));
DELIMITER //
CREATE TRIGGER transfer_to_passive BEFORE DELETE ON employee
FOR EACH ROW
BEGIN
INSERT into employee_inactive
SELECT empid,fname,mname,lname,gender,emptype,hno,street,city,state,date_of_joining,CURRENT_DATE,email FROM employee WHERE employee.empid=OLD.empid;
END;//
DELIMITER ;
DELIMITER //
CREATE TRIGGER on_insertemployee_update_dept
AFTER INSERT ON employee
for EACH ROW
BEGIN
SET @ab=(SELECT dept_headid FROM department WHERE department.deptid=NEW.deptid);
UPDATE department SET dept_headid=CASE
WHEN (@ab is NULL AND department.deptid=NEW.deptid)
THEN new.empid
else dept_headid
END;
END;//
DELIMITER ;
CREATE TABLE prev_department(
empid int,
deptid int,
date_of_joining date,
date_of_leaving date,
PRIMARY KEY(empid,deptid,date_of_leaving));
DELIMITER //
CREATE TRIGGER transfer_to_prev_department AFTER UPDATE ON employee
FOR EACH ROW
BEGIN
IF NEW.deptid<>OLD.deptid THEN
INSERT into prev_department values(OLD.empid,OLD.deptid,OLD.since,CURRENT_TIMESTAMP);
SET @ab=(SELECT dept_headid FROM department WHERE department.deptid=NEW.deptid);
UPDATE department SET dept_headid=CASE
WHEN (@ab is NULL)
THEN new.empid
else dept_headid
END;
SET @bb=(SELECT dept_headid FROM department WHERE department.deptid=OLD.deptid);
IF OLD.empid=@bb THEN
SET @gb=(SELECT empid FROM employee WHERE deptid=OLD.deptid);
SET @mn=(SELECT MIN(since) FROM employee WHERE empid=@gb);
SET @mm=(SELECT MIN(empid) FROM employee WHERE employee.since=@mn);
UPDATE department SET dept_headid=@mm WHERE department.deptid=OLD.deptid;
END IF;
END IF;
END;//
DELIMITER ;
DELIMITER //
CREATE TRIGGER employee_on_delete AFTER DELETE ON employee
FOR EACH ROW
BEGIN
INSERT into prev_department values(OLD.empid,OLD.deptid,OLD.since,CURRENT_TIMESTAMP);
SET @bb=(SELECT dept_headid FROM department WHERE department.deptid=OLD.deptid);
IF OLD.empid=@bb THEN
SET @gb=(SELECT empid FROM employee WHERE deptid=OLD.deptid);
SET @mn=(SELECT MIN(since) FROM employee WHERE empid=@gb);
SET @mm=(SELECT MIN(empid) FROM employee WHERE employee.since=@mn);
UPDATE department SET dept_headid=@mm WHERE department.deptid=OLD.deptid;
END IF;
END;//
DELIMITER ;
INSERT INTO test VALUES(1,"X-RAY",100);
INSERT INTO test VALUES(2,"BLOOD TEST",300);
INSERT INTO test VALUES(3,"URINE TEST",100);
INSERT INTO test VALUES(4,"MRI SCAN",1200);
INSERT INTO test VALUES(5,"ENDOSCOPY",3000);
INSERT INTO test VALUES(6,"BIOPSY",3500);
INSERT INTO test VALUES(7,"ULTRASOUND",900);
INSERT INTO test VALUES(8,"CT-SCAN",1100);
INSERT INTO test VALUES(9,"CBC",350);
INSERT INTO test VALUES(10,"FLU TEST",1500);
INSERT INTO salary VALUES("DOCTOR",70000);
INSERT INTO salary VALUES("NURSE",25000);
INSERT INTO salary VALUES("RECEPTIONIST",20000);
INSERT INTO salary VALUES("ACCOUNTANT",15000);
INSERT INTO salary VALUES("CLEANER",14000);
INSERT INTO salary VALUES("SECURITY",12000);
INSERT INTO salary VALUES("AMBULANCE DRIVER",13000);
INSERT INTO medicine VALUES(1,"CROCINE",10);
INSERT INTO medicine VALUES(2,"ASPIRIN",8);
INSERT INTO medicine VALUES(3,"NAMOSLATE",8);
INSERT INTO medicine VALUES(4,"GLUCOSE",200);
INSERT INTO medicine VALUES(5,"TARIVID",80);
INSERT INTO medicine VALUES(6,"CANESTEN",12);
INSERT INTO medicine VALUES(7,"DICLOFENAC",18);
INSERT INTO medicine VALUES(8,"ANTACIDS",8);
INSERT INTO medicine VALUES(9,"VERMOX",40);
INSERT INTO medicine VALUES(10,"OVEX",25);
INSERT INTO medicine VALUES(11,"OMEE",35);
INSERT INTO medicine VALUES(12,"AVIL",4);
INSERT INTO medicine VALUES(13,"HIDRASEC",50);
INSERT INTO medicine VALUES(14,"UTINOR",80);
INSERT INTO medicine VALUES(15,"PARIET",8);
INSERT INTO medicine VALUES(16,"CIPROXIN",6);
INSERT INTO medicine VALUES(17,"CYPROSTAT",12);
INSERT INTO medicine VALUES(18,"ANDROCUR",80);
INSERT INTO medicine VALUES(19,"DESTOLIT",82);
INSERT INTO medicine VALUES(20,"URSOFALK",15);
INSERT INTO medicine VALUES(21,"ORS",7);
INSERT INTO medicine VALUES(22,"URSOGAL",20);
INSERT INTO medicine VALUES(23,"OMNI GEL",30);
INSERT INTO medicine VALUES(24,"DETTOL",45);
INSERT INTO medicine VALUES(25,"BETADINE",8);
INSERT INTO medicine VALUES(26,"LIVER-52",100);
INSERT INTO medicine VALUES(27,"METHYLPHENIDATE",12);
INSERT INTO medicine VALUES(28,"BETA-BLOCKER",90);
INSERT INTO medicine VALUES(29,"BENZODIAZEPINES",120);
INSERT INTO medicine VALUES(30,"Z-DRUG",150);
INSERT INTO medicine VALUES(31,"ANTIPSYCHOTIC",200);
INSERT INTO medicine VALUES(32,"SSRI-ANTIDEPRESSANT",250);
INSERT INTO medicine VALUES(33,"MAOI-DRUG",140);
INSERT INTO medicine VALUES(34,"BICASUL",1);
INSERT INTO medicine VALUES(35,"NASAL DECONGESTANTS",20);
INSERT INTO medicine VALUES(36,"EXPECTORANTS",10);
INSERT INTO medicine VALUES(37,"COUGH SUPRESSANTS",60);
INSERT INTO medicine VALUES(38,"ANTI HISTAMINES",40);
INSERT INTO medicine VALUES(39,"ACETAMINOPHEN",60);
INSERT INTO medicine VALUES(40,"HPV VACCINE",140);
INSERT INTO medicine VALUES(41,"SYRINGE",3);
INSERT INTO medicine VALUES(42,"INJECTION",10);
INSERT INTO medicine VALUES(43,"MORFIN",5);
INSERT INTO medicine VALUES(44,"ORLISTAT",10);
INSERT INTO medicine VALUES(45,"ZALASTA",85);
INSERT INTO medicine VALUES(46,"ZANTAC",84);
INSERT INTO medicine VALUES(47,"ZEFFIX",82);
INSERT INTO medicine VALUES(48,"ZINNAT",100);
INSERT INTO medicine VALUES(49,"ZOFRAN",80);
INSERT INTO medicine VALUES(50,"ZOCOR",18);
DELIMITER //
CREATE TRIGGER update_nurse_assigned BEFORE INSERT ON employee
FOR EACH ROW
BEGIN
IF NEW.emptype="NURSE" THEN
INSERT INTO nurse_assigned VALUES(New.empid,0);
end if;
end; //
DELIMITER ;
DELIMITER //
CREATE TRIGGER decrease_on_discharge BEFORE INSERT ON bill
FOR EACH ROW
BEGIN
UPDATE room set isfree=0 WHERE rid=(SELECT rid FROM in_patient WHERE in_patient.pid=NEW.pid AND discharge_date is null);
UPDATE nurse_assigned SET countpatient=countpatient-1 WHERE nid=(SELECT nid FROM in_patient WHERE in_patient.pid=NEW.pid AND discharge_date is null);
END; //
DELIMITER ;
insert into department values(1,"ALLERGY",NULL);
insert into department values(2,"INTENSIVE CARE",NULL);
insert into department values(3,"ANESTHESIOLOGY",NULL);
insert into department values(4,"CARDIOLOGY",NULL);
insert into department values(5,"ENT",NULL);
insert into department values(6,"NEUROLOGY",NULL);
insert into department values(7,"ORTHOPEDICS",NULL);
insert into department values(8,"PATHOLOGY",NULL);
insert into department values(9,"RADIOLOGY",NULL);
insert into department values(10,"SURGERY",NULL);
insert into department values(11,"NURSE",NULL);
insert into department values(12,"ACCOUNTS",NULL);
insert into department values(13,"SECURITY",NULL);
insert into department values(14,"CLEANER",NULL);
ALTER TABLE employee ADD FOREIGN KEY(deptid) REFERENCES department(deptid) ON UPDATE CASCADE;
ALTER TABLE employee ADD FOREIGN KEY(emptype) REFERENCES salary(etype) ON DELETE RESTRICT;
DELIMITER //
CREATE TRIGGER delete_null_disease_from_outpatient AFTER INSERT ON bill
FOR EACH ROW
BEGIN
#SET @bb=SELECT pid,arrival_date FROM out_patient WHERE out_patient.pid=NEW.pid AND arrival_date is NULL;
DELETE FROM out_patient WHERE disease is NULL;
END; //
DELIMITER ;
CREATE TABLE doctor(
doc_id int,
qualification varchar(20),
PRIMARY KEY(doc_id),
FOREIGN KEY(doc_id) REFERENCES employee(empid) ON DELETE CASCADE);