全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:934
推到 Plurk!
推到 Facebook!

Stuck............. In Question 4

尚未結案
tabobomber
一般會員


發表:8
回覆:9
積分:3
註冊:2005-04-07

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-04-07 22:53:38 IP:203.55.xxx.xxx 未訂閱
Can somebody pls help me..... I'm stuck on question 4. don't know how to compare..... the question is: 4. The data stored about admissions is sometimes entered incorrectly in that admission and discharge dates are swapped about. Determine whether there are any examples of this in the current database content, and if so, reverse the two dates. can somebody pls help......... ah, 20 questions all together. and I'm just in question 4................... CREATE TABLE admission( patientID char(4), admissionDate date, dischargeDate date, reason char(1), wardNumber char(2), bedNumber number, constraint admission_pk primary key (patientID, admissionDate), constraint admission_bed_fk foreign key (wardNumber, bedNumber) references bed (wardNumber, bedNumber)); INSERT INTO admission VALUES('1234','24-JAN-04','29-JAN-04','H','B1',3); INSERT INTO admission VALUES('1234','21-SEP-04','29-SEP-04','H','B1',4); INSERT INTO admission VALUES('1234','24-JAN-05','28-JAN-05','N','B1',3); INSERT INTO admission VALUES('1491','24-JAN-04','31-JAN-04','N','B1',2); INSERT INTO admission VALUES('2378','22-SEP-04','27-SEP-04','H','B1',1); INSERT INTO admission VALUES('1491','24-JAN-05','03-FEB-05','N','B1',4); INSERT INTO admission VALUES('2386','22-DEC-04','25-DEC-04','C','B1',3); INSERT INTO admission VALUES('2378','25-DEC-04','28-DEC-04','C','B1',2); INSERT INTO admission VALUES('1387','21-DEC-04',null,null,'B2',1); INSERT INTO admission VALUES('1491','24-FEB-05','22-FEB-05','C','B1',4); INSERT INTO admission VALUES('1234','1-MAR-05',null,null,'B2',3); INSERT INTO admission VALUES('2378','2-MAR-05',null,null,'A1',1);
NO.5
初階會員


發表:18
回覆:35
積分:25
註冊:2005-02-23

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-04-08 16:19:31 IP:210.64.xxx.xxx 未訂閱
I think that it's so easy.Maybe you can use code like this:
UPDATE admission
   SET admissionDate = dischargeDate,
       dischargeDate = admissionDate
 WHERE NVL(dischargeDate,SYSDATE) - admissionDate < 0;
You can try it.
tabobomber
一般會員


發表:8
回覆:9
積分:3
註冊:2005-04-07

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-04-09 12:17:00 IP:203.55.xxx.xxx 未訂閱
PROMPT ---------------------------------------------------------------------------; PROMPT "Reverse the Admission and Discharge dates into order" PROMPT ---------------------------------------------------------------------------; PROMPT "Check the date of the table" SELECT patientID, admissionDate, dischargeDate FROM admission; PROMPT ---------------------------------------------------------------------------; PROMPT "Test the incorrect entry" select patientID,admissionDate, dischargeDate from admission where admissionDate >= dischargeDate; PROMPT ---------------------------------------------------------------------------; PROMPT "REVERSE THE DAY" UPDATE admission SET admissionDate = dischargeDate, dischargeDate = admissionDate WHERE NVL(dischargeDate,SYSDATE ) - admissionDate < 0; I've tried, but doesn't work................. what should I do?
wct
一般會員


發表:5
回覆:17
積分:4
註冊:2002-06-07

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-04-11 10:45:27 IP:61.220.xxx.xxx 未訂閱
Hi,    I think you should not do that:    UPDATE admission    SET admissionDate = dischargeDate,        dischargeDate = admissionDate  WHERE NVL(dischargeDate,SYSDATE) - admissionDate < 0;    The contents of admissionDate were updated while you firstly made "SET admissionDate = dischargeDate,". After this had been done, the original contents of admissionDate were lost.    In my opinions, You could try the following:    1.Alter Table admission Add TempDate Date; 2.Update admission SET TempDate=dischargeDate; 3.Update admission SET TempDate=admissionDate,   admissionDate=dischargeDate   Where dischargeDate
wct
一般會員


發表:5
回覆:17
積分:4
註冊:2002-06-07

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-04-11 11:11:04 IP:61.220.xxx.xxx 未訂閱
Sorry for typing mistakes: 1.Alter Table admission Add TempDate Date; 2.Update admission SET TempDate=dischargeDate; 3.Update admission SET TempDate=admissionDate, admissionDate=dischargeDate Where dischargeDate < admissionDate; 4.Update admission SET dischargeDate=TempDate; 5.Alter Table admission Drop TempDate; Good luck! wct
NO.5
初階會員


發表:18
回覆:35
積分:25
註冊:2005-02-23

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-04-11 16:34:09 IP:210.64.xxx.xxx 未訂閱
引言: I've tried, but doesn't work................. what should I do?
N............ Could you tell me what's kind of database you used?
tabobomber
一般會員


發表:8
回覆:9
積分:3
註冊:2005-04-07

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-04-11 18:03:15 IP:203.55.xxx.xxx 未訂閱
it works now ! thx for u guys, really kind! thx again
系統時間:2024-06-26 22:17:18
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!