数据库作业五:SQL练习2 - INDEX / INSERT / SELECT

INDEX:

1.建立索引

建立索引使用CREAT INDEX语句:

CREATE [UNIQUE] [CLUSTERED | NONCLUSTERED] INDEX <索引名> ON <表名>(<列名>[<次序>][,<列名>[<次序>] ]);

[3.13] 为学生-课程数据库中的Student,Course,SC三个表建立索引。Student表按学号升序建唯一索引,Course表按课程号升序建唯一索引,SC表按学号升序和课程号降序建唯一索引

 CREATE UNIQUE INDEX  Stusno ON Student(Sno);
 CREATE UNIQUE INDEX  Coucno ON Course(Cno);
 CREATE UNIQUE INDEX  SCno ON SC(Sno ASC,Cno DESC);

2.修改索引
对于已建立的索引,如果需要对其重新命名。可以使用ALTER INDEX语句,一般格式为:

ALTER INDEX <旧索引名> RENAME TO <新索引名>

[例3.14] 将SC表的SCno索引名改为SCSno

ALTER INDEX SCno RENAME TO SCSno;

3.删除索引

删除索引使用DROP INDEX语句:

DROP INDEX <索引名>;

[例3.15] 删除Student表的Stusname索引

DROP INDEX Student.Stusname;

INSERT:

插入元组的INSERT语句格式为:

INSERT
INTO <表名>[(<属性列1>[,<属性列2>]...)]
VALUES(<常量1>[,<常量2>]...);

[例3.69]将一个新学生元组(学号:201215128;姓名:陈冬;性别:男;所在系:IS;年龄:18岁)插入到Student表中。

INSERT
INTO  Student (Sno,Sname,Ssex,Sdept,Sage)
VALUES ('201215128','陈冬','男','IS',18);

[例3.70]将学生张成民的信息插入到Student表中。

INSERT
INTO Student
VALUES('201215126','张成民','男',18,'IS');

与例3.69的不同是在INTO子句中只指出了表名, 没有指出属性名。这表示新元组要在表的所有属性列上都指定值, 属性列的次序与CREATE TABLE中的次序相同。VALUES子句对新元组的各属性列赋值,一定要注意值与属性列要一一对应,如果像例3.69那样,成为(201215126, 张成民, 男’, CS’, 18) , 则含义是将’CS’赋子了列Sage, 而18赋予了列S dept,这样则会因为数据类型不匹配出错。

在这里插入图片描述
[例3.71] 插入一条选课记录( ‘200215128’,'1 ')。

 INSERT
 INTO SC(Sno,Cno)
 VALUES ('201215128','1');

关系数据库管理系统将在新插入记录的Grade列上自动地赋空值。
或者:

INSERT
INTO SC
VALUES('201215128','1',NULL);

在这里插入图片描述

SELECT:

1.选择表中若干列
(1)查询指定列

SELECT <列名>[,<列名2>,....]
FROM <表名>;

[例3.16] 查询全体学生的学号与姓名。

SELECT Sno,Sname
FROM Student;

在这里插入图片描述
[例3.17] 查询全体学生的姓名、学号、所在系。

SELECT Sname,Sno,Sdept
FROM Student;

在这里插入图片描述
(2).查询全部列

SELECT *
FROM <表名>;

[例3.18] 查询全体学生的详细记录。

SELECT *
FROM Student;

在这里插入图片描述
(3).查询经过计算的值

SELECT <函数表达式>
FROM <表名>;

[例3.19] 查全体学生的姓名及其出生年份。

SELECT Sname,2020-Sage
FROM Student;

在这里插入图片描述
[例3.20] 查询全体学生的姓名、出生年份和所在的院系,要求用小写字母表示系名。

SELECT Sname NAME,'Year of Birth:' BIRTH,2020-Sage BIRTHDEY,LOWER(Sdept) DEPARTMENT
FROM Student;

在这里插入图片描述
可以通过指定别名来改变查询结果的列标题:

SELECT Sname NAME,'Year of Birth:'  BIRTH,
       2020-Sage  BIRTHDAY,LOWER(Sdept)  DEPARTMENT
FROM Student;

在这里插入图片描述

2.选择表中若干元组
(1)。消除取值重复的行
[例3.21] 查询选修了课程的学生学号。

SELECTALL) Sno
FROM SC;

在这里插入图片描述
删除重复行:

SELECT DISTINCT Sno
FROM SC; 

在这里插入图片描述
(2).查询满足条件的元组

①比较大小
[例3.22] 查询计算机科学系全体学生的名单。

SELECT Sname
FROM Student
WHERE Sdept='CS';

在这里插入图片描述
[例3.23]查询所有年龄在20岁以下的学生姓名及其年龄。

SELECT Sname,Sage
FROM Student
WHERE Sage<20;

在这里插入图片描述
[例3.24]查询考试成绩有不及格的学生的学号。

SELECT DISTINCT Sno
FROM SC
WHERE Grade<60;

在这里插入图片描述
②.确定范围

[例3.25] 查询年龄在20~23岁(包括20岁和23岁)之间的学生的姓名、系别和年龄。

SELECT Sname,Sdept,Sage
FROM Student
WHERE Sage BETWEEN 20 AND 23;

在这里插入图片描述
[例3.26] 查询年龄不在20~23岁之间的学生姓名、系别和年龄

SELECT Sname,Sdept,Sage
FROM Student
WHERE Sage NOT BETWEEN 20 AND 23;

在这里插入图片描述
[例3.27]查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别。

SELECT Sname, Ssex
FROM  Student
WHERE Sdept IN ('CS','MA','IS');

在这里插入图片描述
[例3.28]查询既不是计算机科学系、数学系,也不是信息系的学生的姓名和性别。

SELECT Sname, Ssex
FROM Student
WHERE Sdept NOT IN ('IS','MA','CS');

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值