數據庫作業10:第三章課後題

3、有兩個關係S(A,B,C,D)和T(C,D,E,F),寫出與下列查詢等價的SQL表達式;
(1)σA=10(S)\sigma_{A=10}(S)
σ\sigma:選擇運算符,選出符合條件的元組。

SELECT *
FROM S
WHERE A='10';

(2)ΠA,B(S)\Pi_{A,B}(S)
Π\Pi:投影運算符,選出一些列。

SELECT A,B
FROM S;

(3) STS\Join T
\Join:自然連接,去掉重複列

SELECT A,B,S.C,S.D,E,F
FROM S,T
WHERE S.C=T.C AND S.D=T.D;

(4) SS.C=T.CTS \underset{S.C=T.C}\Join T

SELECT *
FROM S,T
WHERE S.C=T.C;

(5) SA<ETS \underset{A<E}\Join T

SELECT *
FROM S,T
WHERE A<E;

(6)ΠC,D(S)×T\Pi_{C,D}(S) \times T

/*這是我寫的,正確*/
SELECT *
FROM T,(SELECT C,D
		FROM S)
		AS CD(C,D)
/*答案寫的,簡單*/
SELECT S.C,S.D,T.*
FROM S,T;

測試得到我的寫法也是正確的,但是沒有答案的簡單。
4、用SQL語句建立第2章習題6中的4個表:針對建立的4各表用SQL完成第2章習題6中的查詢。
在這裏插入圖片描述
在這裏插入圖片描述
建表:

/*一定要注意中英文字符的轉換,這麼多的數據容易搞混,切記切記!!!*/
/*建表S並插入數據*/
CREATE TABLE S(SNO nchar(10),
			   SNAME nchar(10),
			   STATUS int,
			   CITY char(10))
INSERT INTO S VALUES('S1','精益',20,'天津');
INSERT INTO S VALUES('S2','盛錫',10,'北京');
INSERT INTO S VALUES('S3','東方紅',30,'北京');
INSERT INTO S VALUES('S4','豐泰盛',20,'天津');
INSERT INTO S VALUES('S5','爲民',30,'上海');

/*建立P表並插入數據*/
CREATE TABLE P(PNO nchar(10),
			   PNAME nchar(10),
			   COLOR nchar(10),
			   WEIGHT int);
INSERT INTO P VALUES('P1','螺母','紅',12);
INSERT INTO P VALUES('P2','螺栓','綠',17);
INSERT INTO P VALUES('P3','螺絲刀','藍',14);
INSERT INTO P VALUES('P4','螺絲刀','紅',14);
INSERT INTO P VALUES('P5','凸輪','藍',40);
INSERT INTO P VALUES('P6','齒輪','紅',30);

/*建立J表並插入數據*/
CREATE TABLE J(JNO nchar(10),
			   JNAME nchar(10),
			   CITY nchar(10));
INSERT INTO J VALUES('J1','三建','北京');
INSERT INTO J VALUES('J2','一汽','長春');
INSERT INTO J VALUES('J3','彈簧廠','天津');
INSERT INTO J VALUES('J4','造船廠','天津');
INSERT INTO J VALUES('J5','機車廠','唐山');
INSERT INTO J VALUES('J6','無線電廠','常州');
INSERT INTO J VALUES('J7','半導體廠','南京');

/*建立SPJ表並插入數據*/
CREATE TABLE SPJ(SNO nchar(10),
				 PNO nchar(10),
				 JNO nchar(10),
				 QTY int);
INSERT INTO SPJ VALUES('S1','P1','J1',200);
INSERT INTO SPJ VALUES('S1','P1','J3',100);
INSERT INTO SPJ VALUES('S1','P1','J4',700);
INSERT INTO SPJ VALUES('S1','P2','J2',100);
INSERT INTO SPJ VALUES('S2','P3','J1',400);
INSERT INTO SPJ VALUES('S2','P3','J2',200);
INSERT INTO SPJ VALUES('S2','P3','J4',500);
INSERT INTO SPJ VALUES('S2','P3','J5',400);
INSERT INTO SPJ VALUES('S2','P5','J1',400);
INSERT INTO SPJ VALUES('S2','P5','J2',100);
INSERT INTO SPJ VALUES('S3','P1','J1',200);
INSERT INTO SPJ VALUES('S3','P3','J1',200);
INSERT INTO SPJ VALUES('S4','P5','J1',100);
INSERT INTO SPJ VALUES('S4','P6','J3',300);
INSERT INTO SPJ VALUES('S4','P6','J4',200);
INSERT INTO SPJ VALUES('S5','P2','J4',100);
INSERT INTO SPJ VALUES('S5','P3','J1',200);
INSERT INTO SPJ VALUES('S5','P6','J2',200);
INSERT INTO SPJ VALUES('S5','P6','J4',500);

(1)求供應工程J1零件的供應商號碼SNO;

SELECT DISTINCT SNO
FROM SPJ
WHERE JNO='J1';

在這裏插入圖片描述
(2)求供應工程J1零件P1 的供應商號碼SNO;

SELECT SNO
FROM SPJ
WHERE JNO='J1' AND PNO='P1';

在這裏插入圖片描述
(3)求供應工程J1零件爲紅色的供應商號碼SNO;

SELECT SNO
FROM P,SPJ
WHERE P.PNO=SPJ.PNO AND JNO='J1' AND COLOR='紅';

在這裏插入圖片描述
(4)求沒有使用天津供應商生產的紅色零件的工程號JNO;

/*我的答案*/
SELECT DISTINCT JNO 
FROM SPJ,(SELECT SNO,CITY,PNO,COLOR
			FROM S,P
			WHERE CITY!='天津' OR COLOR!='紅')
			AS SP(SNO,CITY,PNO,COLOR)
WHERE SP.SNO=SPJ.SNO AND SP.PNO=SPJ.PNO
/*參考答案*/
SELECT DISTINCT JNO
FROM  SPJ
WHERE  JNO NOT IN(
SELECT JNO
FROM S,P,SPJ
WHERE S.SNO=SPJ.SNO AND P.PNO=SPJ.PNO AND COLOR='紅' AND CITY='天津')

在這裏插入圖片描述
在這裏插入圖片描述
自己感覺沒有錯誤,但是和答案有點不太一樣。
(5)求至少用了供應商S1所供應的全部零件的工程號JNO。
對於任意的S1提供的零件JNO全部使用。

SELECT DISTINCT JNO
FROM SPJ SPJ1
WHERE NOT EXISTS
			(SELECT *
			FROM SPJ SPJ2
			WHERE SPJ2.SNO='S1' AND NOT EXISTS
				(SELECT *
				FROM SPJ SPJ3
				WHERE SPJ3.JNO=SPJ1.JNO AND SPJ3.PNO=SPJ2.PNO))

自己沒有寫出來,看了以下以前的例題【例3.63】.

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 P.PNO=SPJ.PNO AND JNO='J2';

在這裏插入圖片描述
(5)找出上海廠商供應的所有零件號碼。

/*這是我寫的,正確*/
SELECT  DISTINCT PNO
FROM SPJ
WHERE SNO IN(SELECT SNO
			 FROM S
			 WHERE CITY='上海')
/*這是答案寫的*/
SELECT DISTINCT PNO 
FROM S,SPJ
WHERE S.SNO=SPJ.SNO AND CITY='上海'

測試操作後,我的答案也是正確的。
在這裏插入圖片描述
(6)找出使用上海產的零件的工程名稱。

/*這是我寫的,正確*/
SELECT  DISTINCT JNAME
FROM J
WHERE JNO IN(SELECT JNO
			 FROM SPJ
			 WHERE SNO IN(SELECT SNO
						  FROM S
						  WHERE CITY='上海'))
/*這是答案寫的*/
SELECT DISTINCT JNAME
FROM SPJ,S,J
WHERE SPJ.SNO=S.SNO AND SPJ.JNO=J.JNO AND S.CITY='上海';

在這裏插入圖片描述

(7)找出沒有使用天津產的零件的工程號碼。

SELECT JNO
FROM SPJ
WHERE JNO NOT IN (SELECT JNO
				FROM SPJ
				WHERE SNO IN
					(SELECT SNO
					FROM S
					WHERE CITY='天津'))  

或者

SELECT JNO
FROM SPJ
WHERE JNO NOT IN (SELECT DISTINCT  JNO
FROM SPJ,S
WHERE S.SNO=SPJ.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';

DELETE 
FROM SPJ
WHERE SNO='S2'

在這裏插入圖片描述
(11)請將(S2,J6,P4,200)插入供應情況關係。

INSERT 
INTO SPJ
VALUES('S2','J6','P4',200);

9、請爲三建工程項目建立一個供應情況的視圖,包括供應商的代碼(SNO)、零件代碼(PNO)、供應數量(QTY)。針對該視圖完成下列查詢:

/*建立視圖*/
CREATE VIEW S_P2
AS
SELECT SNO,PNO,QTY
FROM SPJ,J
WHERE JNAME='三建' AND SPJ.JNO=J.JNO

在這裏插入圖片描述
(1)找出三建工程項目所使用的各種零件代碼及其數量。

SELECT PNO,QTY
FROM S_P;

(2)找出供應商S1的供應情況。

SELECT SNO,PNO,QTY
FROM S_P
WHERE SNO='S1';

通過做題發現,自己對於嵌套查詢尤其是帶有EXISTS謂詞的子查詢的掌握仍然不夠,還需要繼續加強。
還要有使用連接查詢的意識,有幾道題使用連接可以更加輕鬆,但是我選擇了稍微複雜的方法,不過也是正確的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章