admin管理员组文章数量:1532656
2024年6月4日发(作者:)
数据库原理与应用(SQL Server)练习题 - 1 -
/zh-cn/library/
实验1 数据库操作
1.创建数据库:
操作1.1:创建一个test数据库,其主数据文件逻辑名test_data,物理文件名test_,初始大小
10MB,最大尺寸为无限大,增长速度1MB;数据库日志文件逻辑名称为test_log,物理文件名为test_,
初始大小为1MB,最大尺寸为5MB,增长速度为10%。
参考答案:
create database Test
ON primary
(
)
LOG ON
(
)
GO
name = test_log,
filename = 'd:testtest_',
size = 1MB,
maxsize = 5MB,
filegrowth = 10%
name = test_data,
filename = 'd:testtest_',
size = 5MB,
maxsize = unlimited,
filegrowth = 1MB
2.查看数据库属性:
操作1.2:使用T-SQL语句查看数据库test属性
参考答案:
EXEC sp_helpdb test
EXEC 执行存储过程
sp_helpdb 报告有关指定数据库或所有数据库的信息。
3.删除数据库:
操作1.3:使用T-SQL语句删除数据库test
参考答案:
数据库原理与应用(SQL Server)练习题 - 2 -
drop database Test
实验2 表操作
1.创建表:
操作2.1:创建学生表:
表名:student
属性列
st_id
st_nm
st_sex
st_birth
st_score
st_date
st_from
st_dpid
st_mnt
数据类型
nVarChar
nVarChar
nVarChar
datetime
int
datetime
nChar
nVarChar
tinyint
长度
9
8
2
20
2
说明:学生基本信息表
空值
Not Null
Not Null
Null
Null
Null
Null
Null
Null
Null
列约束
PK
说明
学生学号
学生姓名
学生性别
出生日期
入学成绩
入学日期
学生来源
所在系编号
学生职务
参考答案:
USE test
GO
CREATE TABLE student
(
st_id nVarChar(9) primary key NOT NULL ,
st_nm nVarChar(8) NOT NULL ,
st_sex nVarChar(2) NULL ,
st_birth datetime NULL ,
st_score int NULL ,
st_date datetime NULL ,
st_ from nVarChar(20) NULL ,
st_dpid nVarChar(2) NULL ,
st_ mnt tinyint NULL
)
GO
数据库原理与应用(SQL Server)练习题 - 3 -
操作2.2:创建课程信息表:
表名:couse
属性列
cs_id
cs_nm
cs_tm
cs_sc
数据类型
nVarChar
nVarChar
int
int
长度
4
20
说明:课程信息表
空值
Not Null
Not Null
Null
Null
列约束
PK
说明
课程编号
课程名称
课程学时
课程学分
参考答案:
USE test
GO
CREATE TABLE couse
(
cs_id nVarChar(4) primary key NOT NULL ,
cs_nm nVarChar(20) NOT NULL ,
cs_tm int NULL ,
cs_sc int NULL
)
GO
操作2.3:创建选课表:
表名:slt_couse
属性列
cs_id
st_id
score
sltdate
数据类型
nVarChar
nVarChar
int
datetime
长度
4
9
说明:选课表
空值
Not Null
Not Null
Null
Null
列约束
FK
FK
说明
课程编号
学生编号
课程成绩
选课日期
参考答案:
USE test
GO
CREATE TABLE couse
(
cs_id nVarChar(4) NOT NULL ,
st_id nVarChar(9) NOT NULL ,
score int NULL ,
数据库原理与应用(SQL Server)练习题 - 4 -
sltdate
datetime
)
GO
操作2.4:创建院系信息表:
NULL
表名:dept
属性列
dp_id
dp_nm
dp_drt
dt_tel
数据类型
nVarChar
nVarChar
nVarChar
nVarChar
长度
2
20
8
12
说明:院系信息表
空值
Not Null
Not Null
Null
Null
列约束
系编号
院系名称
院系主任
联系电话
说明
参考答案:
USE test
GO
CREATE TABLE dept
(
dp_id nVarChar(2) NOT NULL ,
dp_nm nVarChar(20) NOT NULL ,
dp_drt nVarChar(8) NULL ,
dp_tel nVarChar(12) NULL
)
GO
2.修改表结构:
(1)向表中添加列:
操作2.5:为“dept”表添加“dp_count”列(数据类型为nvarchar,长度为3,允许为空)
参考答案:
ALTER TABLE dept ADD dp_count nvarchar(3) NULL
(2)修改列数据类型:
操作2.6:修改“dept”表的“dp_count”列数据类型为int
参考答案:
ALTER TABLE dept ALTER COLUMN dp_count int NULL
(3)删除表中指定列:
操作2.7:删除“dept”表的“dp_count”列
参考答案:
ALTER TABLE dept DROP COLUMN dp_count
3.删除表
操作2.8:删除“dept”表
数据库原理与应用(SQL Server)练习题 - 5 -
参考答案:
DROP TABLE student
4.向表中输入数据记录
操作2.9:分别向“student”表、“couse”表、“slt_couse”表、“dept”表中输入数据记录
实验3 数据完整性
1.空值约束( NULL )
操作3.1:将student表中的st_sex列属性更改为NOT NULL
参考答案:
ALTER TABLE student ALTER COLUME st_nm nVarChar(8) NOT NULL
2.默认值约束( DEFAULT )
操作3.2:将student表中的st_from列默认值设置为“陕西省”
参考答案:
ALTER TABLE student ADD DEFAULT '陕西省' FOR st_from
3.默认值对象
操作3.3:创建默认值对象df_today为当前日期,并将其绑定到slt_couse表中的sltdate列,然后取消
绑定,最后删除默认值对象df_today。
参考答案:
CREATE DEFAULT df_today AS Getdate( )
GO
EXEC sp_bindefault df_today, 'slt_e'
GO
EXEC sp_unbindefault 'slt_e'
GO
DROP DEFAULT df_today
GO
4.检查约束( CHECK )
操作3.4:将slt_couse表中的score列的检查约束设置为>=0且<=100
参考答案:
ALTER TABLE slt_couse ADD CHECK (score>=0 AND score<=100)
5.规则约束对象
操作3.5:创建规则约束对象rl_sex,用于检查性别的取值仅限于“男”和“女”,并将其绑定到student
表中的st_sex列,然后取消绑定,最后删除规则约束对象rl_sex。
参考答案:
CREATE RULE rl_sex AS @chksex ’男’ OR @chksex=’女’
或
CREATE RULE rl_sex AS @chksex IN (’男’, ’女’)
GO
数据库原理与应用(SQL Server)练习题 - 6 -
EXEC sp_bindrule rl_sex, '_sex'
GO
EXEC sp_unbindrule '_sex'
GO
DROP RULE rl_sex
GO
6.主键
操作3.6:将dept表中的dp_id列设置为主键
参考答案:
ALTER TABLE dept ADD PRIMARY KEY (dp_id)
7.唯一性约束( UNIQUE )
操作3.7:将dept表中的dp_nm列设置为唯一性约束
参考答案:
ALTER TABLE dept ADD UNIQUE (dp_nm)
8.标识列
操作3.8:向slt_couse表中添加标识列id,第1行默认值为1,相邻两个标识列间的增量为1
参考答案:
ALTER TABLE slt_couse ADD id INT IDENTITY(1,1) NOT NULL
9.外键( FOREIGN KEY )
操作3.9:被参照表为dept,参照表为student
参考答案:
ALTER TABLE student
ADD FOREIGN KEY (st_dpid) REFERENCES dept(dp_id)
实验4 数据更新
1.表中插入数据
操作4.1:向dept表插入一条记录,系号11,系名自动控制系,系主任为李其余,电话81234567
INSERT INTO dept VALUES('11', '自动控制系', '李其余', '81234567')
操作4.2:向student表插入一条记录,学号070201001,姓名为王小五,性别为男,出生日期为1990
年9月9日,系号为11,其余字段为NULL或默认值
INSERT INTO student(st_id, st_nm, st_sex, st_birth, st_dpid)
VALUES ('070201001', '王小五', '男', '1990.9.9', '11' )
操作4.3:向couse表插入一条记录,课程号1234,课程名为操作系统,其余字段为NULL或默认值
INSERT INTO couse(cs_id, cs_nm) VALUES ('1234', '操作系统')
操作4.4:向slt_couse表插入一条记录,课程号1234,学名070201001,其余字段为NULL或默认值
INSERT INTO slt_couse(cs_id, st_id) VALUES ('1234', '070201001')
2.修改表中数据
操作4.5:修改student表记录,将王小五的入学成绩改为88
数据库原理与应用(SQL Server)练习题 - 7 -
UPDATE student SET st_score=88 WHERE st_nm='王小五'
操作4.6:修改couse表记录,将所有记录的学分改为4,学时改为64
UPDATE couse SET cs_tm=64, cs_sc=4
操作4.7:修改slt_couse表记录,将课程号为1234,学名为070201001的记录的成绩改为77
UPDATE slt_couse SET score=77 WHERE cs_id='1234' AND st_id='070201001'
3.删除表中数据
操作4.8:删除slt_couse表记录,将课程号为1234,学名为070201001的记录删除
DELETE FROM slt_couse WHERE cs_id='1234' AND st_id='070201001'
操作4.9:删除couse表记录,将课程号为1234的记录删除
DELETE FROM couse WHERE cs_id='1234'
实验5 数据查询(1)——简单查询
(1)查询表中所有的列
操作5.1:查询所有系的信息
SELECT * FROM dept
(2)查询表中指定列的信息
操作5.2:查询所有的课程号与课程名称
SELECT cs_id, cs_nm FROM couse
(3)在查询列表中使用列表达式
操作5.3:在查询student表时使用列表达式:入学成绩+400
SELECT st_id, st_nm, st_score, st_score+400 AS new_score
FROM student
(4)重新命名查询结果
操作5.4:使用AS关键字为dept表中属性指定列名:系号、系名、系主任、联系电话
SELECT dp_id AS 系号, dp_nm AS 系名, dp_drt AS 系主任, dp_tel AS联系电话
FROM dept
操作5.5:使用"="号为couse表中属性指定列名:课程号、课程名、学时(=cs_sc*16)、学分
SELECT 课程号=cs_id, 课程名=cs_nm, 学分=cs_sc, 学时=cs_sc*16
FROM couse
(5)增加说明列
操作5.6:查询dept表的系号、系名和系主任,向查询结果中插入说明列:系号、系名和系主任
SELECT '系号:', st_id, '系名:', st_nm, '系主任:', st_drt
FROM dept
(6)查询列表中使用系统函数
操作5.7:显示所有学生的学号、姓名、性别和入学年份
SELECT st_id, st_nm, st_sex, DATEPART(yy,st_birth) AS 入学年份
FROM student
操作5.8:显示所有学生学号、姓名、性别和班级(学号前6位)
SELECT st_id, st_nm, st_sex, LEFT(st_id, 6) AS 班级
FROM student
(7)消除查询结果中的重复项
操作5.9:显示所有学生班级
SELECT DISTINCT LEFT(st_id,6) AS 班级 FROM student
数据库原理与应用(SQL Server)练习题 - 8 -
(8)取得查询结果的部分行集
操作5.10:显示前5条学生记录信息
SELECT TOP 5 * FROM student
操作5.11:显示前25%条学生记录信息
SELECT TOP 25 PERCENT * FROM student
操作5.12:显示前n条学生记录信息,n为局部变量
DECLARE @n INT
SET @n = 4
SELECT TOP @n * FROM student
实验6 数据查询(2)——条件查询
1.使用关系表达式表示查询条件
操作6.1:查询dept表中系号为11的院系信息
SELECT * FROM dept WHERE dp_id = '11'
操作6.2:查询student表中11系的学生学号、姓名、性别和所在系编号
SELECT st_id, st_nm, st_sex, st_dpid FROM student
WHERE st_dpid = '11'
操作6.3:查询student表中2008年及以后入学的学生信息
SELECT * FROM student
WHERE DATEPART( yy, st_date )>= 2008
操作6.4:在查询student表080808班学生的学号、姓名、性别和入学成绩
SELECT st_id, st_nm, st_sex, st_score FROM student
WHERE Left(st_id,6)='080808'
2.使用逻辑表达式表示查询条件
操作6.5:查询student表中非11系的学生信息
SELECT * FROM student WHERE NOT (st_dpid = '11')
操作6.6:查询选修了1002号课程且成绩在60以下的学生学号
SELECT st_id FROM slt_couse
WHERE (cs_id='1002') AND (score<60)
操作6.7:查询2007年入学的11系所有男生信息
SELECT * FROM student
WHERE DATEPART(yy,st_date)=2007 AND st_dpid='11' AND st_sex='男'
操作6.8:查询11系和12系的学生信息
SELECT * FROM student
WHERE st_dpid='11' OR st_dpid='12'
操作6.9:查询11系和12系所有2007年入学的学生信息
SELECT * FROM student
WHERE (st_dpid='11' OR st_dpid='12') AND DATEPART(yy,st_date)=2007
3.使用LIKE关键字进行模糊查询
操作6.10:查询所有“计算机”开头的课程信息
SELECT * FROM couse WHERE cs_nm LIKE '计算机%'
版权声明:本文标题:SQL Server SQL实验与练习题参考答案 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dianzi/1717452665a573895.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论