3、有两个关系S(A,B,C,D)和T(C,D,E,F),写出与下列查询等价的SQL表达式;
(1)
:选择运算符,选出符合条件的元组。
SELECT *
FROM S
WHERE A='10';
(2)
:投影运算符,选出一些列。
SELECT 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 A<E;
(6)
/*这是我写的,正确*/
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谓词的子查询的掌握仍然不够,还需要继续加强。
还要有使用连接查询的意识,有几道题使用连接可以更加轻松,但是我选择了稍微复杂的方法,不过也是正确的。