【數據庫】作業10——第三章課後題


 

 

作業原地址:作業

 

目錄

 

3.

(1)

 

(2)

(3)

(4)

(5)

(6)

4.

(1)

(2)

(3)

(4)

(5)

5.

(1)

(2)

(3)

(4)

 

(5)

(6)

(7)

(8)

(9)

(10)

(11)

9.

(1)

(2)

總結

 


 

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)

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