作業原地址:作業
目錄
3.
有兩個關係S(A,B,C,D)和T(C,D,E,F),寫出與下列查詢等價的SQL表達式:
(1)
SELECT *
FROM S
WHERE A=10;
(2)
SELECT DISTINCT A,B
FROM S;
(3)
SELECT A,B,S.C,S.D,E,F
FROM S,T
WHERE S.C=T.C AND S.D=T.D
(4)
SELECT *
FROM S,T
WHERE S.C=T.C
(5)
SELECT *
FROM S,T
WHERE S.A<S.E
(6)
SELECT DISTINCT S.C,S.D,T.*
FROM S,T
4.
用SQL語句建立第二章習題6中的4個表;針對建立的4個表用SQL完成第二章習題6中的查詢。
建立S表:
CREATE TABLE S(SNO CHAR(10),
SNAME CHAR(10),
STATUS INT,
CITY CHAR(10),
);
INSERT INTO S(SNO,SNAME,STATUS,CITY) VALUES ('S1','精益',20,'天津');
/*略*/
建立P表:
CREATE TABLE P(PNO CHAR(10),
PNAME CHAR(10),
COLOR CHAR(10),
WEIGHT INT
);
INSERT INTO P(PNO,PNAME,COLOR,WEIGHT) VALUES('P1','螺母','紅',12);
/*略*/
建立J表:
CREATE TABLE J(JNO CHAR(10),
JNAME CHAR(10),
CITY CHAR(10)
);
INSERT INTO J(JNO,JNAME,CITY) VALUES('J1','三建','北京');
/*略*/
建立SPJ表:
CREATE TABLE SPJ(SNO CHAR(4),
PNO CHAR(4),
JNO CHAR(4),
QTY INT
);
INSERT INTO SPJ(SNO,PNO,JNO,QTY) VALUES('S1','P1','J1',200);
/*略*/
(1)
求供應工程J1零件的供應商號碼SNO
SELECT SNO
FROM SPJ
WHERE JNO='J1';
(2)
求供應工程J1零件P1的供應商號碼SNO
SELECT SNO
FROM SPJ
WHERE JNO='J1' AND PNO ='P1';
(3)
求供應工程J1零件P1的供應商號碼SNO
SELECT SNO
FROM SPJ,P
WHERE P.PNO=SPJ.PNO AND JNO='J1' AND COLOR='紅';
(4)
求沒有使用天津供應商生產的紅色零件的工程號JNO
SELECT JNO
FROM J
WHERE NOT EXISTS(
SELECT *
FROM S,P,SPJ
WHERE S.CITY='天津' AND
P.COLOR='紅' AND
SPJ.JNO=J.JNO AND
SPJ.SNO=S.SNO AND
SPJ.PNO=P.PNO);
(5)
求至少用了供應商S1所供應的全部零件的工程號JNO
SELECT DISTINCT JNO
FROM SPJ
WHERE NOT EXISTS
(SELECT *
FROM SPJ
WHERE SPJ.SNO='S1' AND
NOT EXISTS
(SELECT *
FROM SPJ
WHERE SPJ.PNO=SPJ.PNO AND SPJ.JNO=SPJ.JNO));
5.
針對習題4中的4個表使用SQL完成以下各項操作:
(1)
找出所有供應商的姓名和所在城市
SELECT SNAME,CITY
FROM S
(2)
找出所有零件的名稱、顏色、重量
SELECT PNAME,COLOR,WEIGHT
FROM P
(3)
找出使用供應商S1所供應零件的工程號碼
SELECT JNO
FROM SPJ
WHERE SNO='S1'
(4)
找出工程項目J2使用的各種零件的名稱及其數量
SELECT PNAME,QTY
FROM P,SPJ
WHERE JNO='J2' AND P.PNO=SPJ.PNO
(5)
找出上海廠商供應的所有零件號碼
SELECT DISTINCT PNO
FROM SPJ,S
WHERE S.SNO=SPJ.SNO AND CITY='上海'
(6)
找出使用上海產的零件的工程名稱
SELECT DISTINCT JNAME
FROM S,J,SPJ
WHERE S.SNO=SPJ.SNO AND S.CITY='上海' AND J.JNO=SPJ.JNO
(7)
找出沒有使用天津產的零件的工程號碼
SELECT JNO
FROM J
WHERE NOT EXISTS(SELECT *
FROM SPJ,S
WHERE SPJ.JNO=J.JNO AND SPJ.SNO=S.SNO AND S.CITY='天津')
(8)
把全部紅色零件的顏色改成藍色
UPDATE P
SET COLOR='藍'
WHERE COLOR='紅'
(9)
由S5供給J4的零件P6改爲由S3供應,請作必要的修改
UPDATE SPJ
SET SNO='S3'
WHERE SNO='S5' AND JNO='J4' AND PNO='P6';
(10)
從供應商關係中刪除S2的記錄,並從供應情況關係中刪除相應的記錄
DELETE
FROM S
WHERE SNO='S2';
(11)
請將(S2,J6,P4,200)插入供應情況關係
INSERT
INTO SPJ
VALUES('S2','P4','J6',200);
9.
請爲三建工程項目建立一個供應情況的視圖,包括供應商代碼(SNO)、零件代碼(PNO)、供應商數量(QTY)。針對該視圖完成下列查詢:
創建視圖:
CREATE VIEW SPJ
AS
SELECT SNO,PNO,QTY
FROM SPJ
WHERE J.JNO=SPJ.JNO AND J.JNAME='三建'
(1)
找出三建工程項目使用的各種零件代碼及其數量
SELECT PNO,QTY
FROM SPJ
(2)
找出供應商S1的供應情況
SELECT *
FROM SPJ
WHERE SNO='S1'
總結
又是大筆大筆的習題(哭),稍微有點喫勁了,開始得照着例題和模板才能寫出代碼,多做了幾道題,慢慢就上手了,目前還沒遇到什麼大的問題。不過這習題量還是蠻大的......
做習題的時候發現,“;”的問題,查了資料,大多情況下,單組的語句應該是可以不加“;”的,不過問題就是如果手寫的話,寫不寫“;”會不會影響答案。emm
上期傳送門:
下期傳送門:————
完成時間:1h48min
以上
————(2020.3.29)