数据库实验3答案..

数据库实验3答案..
数据库实验3答案..

实验三:交互式SQL语句的使用

1、实验目的

(1)掌握数据库对象的操作过程,包括创建、修改、删除

(2)熟悉表的各种操作,包括插入、修改、删除、查询

(3)熟练掌握常用SQL语句的基本语法

2、实验平台

使用SQL Server提供的Microsoft SQL Server Management Studio工具,交互式使用SQL语句。

3 实验内容及要求

选择如下一个应用背景之一:

●学生选课系统

●习题3、4、和5中使用的数据库

●其它你熟悉的应用

(1)建立一个数据库和相关的表、索引、视图等数据库对象,练习对表、索引和视图的各种操作。

(2)要求认真进行实验,记录各实验用例及执行结果。

(3)深入了解各个操作的功能。

实验要求包括如下方面的内容:

3.1 数据定义

1.基本表的创建、修改及删除

2.索引的创建

3.视图的创建

3.2 数据操作

完成各类更新操作包括:

1.插入数据

2.修改数据

3. 删除数据

3.3 数据查询操作

完成各类查询操作

1.单表查询

2.分组统计

3. 连接查询

4. 嵌套查询

5. 集合查询

3.4 数据操作

1.创建视图

2.视图查询

参考示例:

建立一个学生选课数据库,练习对表、视图和索引等数据库对象的各种操作。

一、数据定义

创建学生选课数据库ST,包括三个基本表,其中Student表保存学生基本信息,Course表保存课程信息,SC表保存学生选课信息,其结构如下表:

表1. Student表结构

表2. Course表结构

表3. SC表结构

1.创建、修改及删除基本表

(1)创建Student表

CREATE TABLE Student

(Sno CHAR(8)PRIMARY KEY,

Sname CHAR(8),

Ssex CHAR(2)NOT NULL,

Sage INT,

Sdept CHAR(20)

);

(2)创建Course表

CREATE TABLE Course

(Cno CHAR(4)PRIMARY KEY,

Cname CHAR(40)NOT NULL,

Cpno CHAR(4),

Ccredit SMALLINT,

);

(3)创建SC表

CREATE TABLE SC

(Sno CHAR(8)FOREIGN KEY (Sno)REFERENCES Student(Sno),

Cno CHAR(4),

Grade SMALLINT,

);

(4)创建员工表Employee

CREATE TABLE Employee

(

编号CHAR(8)PRIMARY KEY,

姓名VARCHAR(8)not null

部门CHR(40),

工资numeric(8,2),

生日datetime,

职称char(20),

);

指出该语句中的错误并改正后执行。

(5)检查表是否创建成功

SELECT*FROM Student

SELECT*FROM Course

SELECT*FROM SC

SELECT*FROM Employee

(6)修改表结构及约束

●增加班级列

ALTER TABLE Student ADD Sclass char(4)

●修改年龄列

ALTER TABLE Student ALTER COLUMN Sage smallint

●增加约束

ALTER TABLE Course ADD UNIQUE(Cname)

(7)删除表

DROP TABLE Employee

2.创建索引

(1)为Course表按课程名称创建索引

CREATE INDEX iCname On Course(Cname)

(2)为Student表按学生姓名创建唯一索引

CREATE UNIQUE INDEX iSname ON Student(Sname) (3)为SC表按学号和课程号创建聚集索引

CREATE CLUSTERED INDEX iSnoCno On SC(Sno,Cno desc) (4)为Course表按课程号创建唯一索引

请自己完成该操作

3.创建视图

建立信息系学生的视图:

CREATE VIEW IS_Student

AS

SELECT Sno,Sname,Sage FROM Student

WHERE Sdept='IS';

3.2 数据操作

1.插入数据

将如下表格中的数据分别插入到数据库相应的表中:

表4.学生基本信息表

表5.课程信息表

表6.学生选课信息表

(1)插入到Student表

INSERT INTO Student VALUES('20100001','李勇','男',20,'CS','1001')

INSERT INTO Student VALUES('20100002','刘晨','女',19,'CS','1001')

INSERT INTO Student(Sno,Sname,Ssex,Sage,Sdept,Sclass)VALUES('20100021','王敏','女',18,'MA','1002') INSERT INTO Student(Sno,Sname,Ssex,Sage,Sdept,sclass)VALUES('20100031','张立','男',19,'IS','1003') INSERT INTO Student(Sno,Sname,Ssex,sclass)VALUES('20100003','刘洋','女','1001')

检查下列语句中的错误,并改正:

INSERT INTO Student(Sno,Sname,Ssex,Sage,Sdept,sclass) VALUES('20100010',赵斌,'男','19','IS','1005') INSERT INTO Student VALUES('20100022','张明明',19,'男','CS','1002')

(2)插入到Course表

INSERT INTO Course(Cno,Cname,Cpno,Ccredit)VALUES('1','数据库系统原理','5',4)

INSERT INTO Course(Cno,Cname,Cpno,Ccredit)VALUES('2','高等数学',null,2)

INSERT INTO Course(Cno,Cname,Cpno,Ccredit)VALUES('3','管理信息系统','1',4)

请写出插入其余行的插入语句,并插入数据。

(3)插入到SC表

INSERT INTO SC VALUES('20100001','1',92)

INSERT INTO SC VALUES('20100002','2',80)

INSERT INTO SC(Sno,Cno)VALUES('20100003','1')

INSERT INTO SC(Sno,Cno,Grade)VALUES('20100010','3',null)

请写出插入其余行的插入语句,并运行。

(4)多行插入到表中

创建存一个表,保存学生的学号、姓名和年龄:

CREATE TABLE cs_Student

(

学号char(8),

姓名char(8),

年龄smallint

);

插入数据行:

INSERT INTO cs_Student

SELECT Sno,Sname,Sage

FROM student Where Sdept='CS';

(5)检查插入到表中的数据

SELECT*FROM Student

SELECT*FROM Course

SELECT*FROM SC

2.修改数据

(1)将学生20100001的年龄改为22岁。

UPDATE student SET Sage= 22 WHERE Sno='20100001';

(2)将所有学生的年龄增加一岁。

UPDATE Student SET Sage=Sage+1

(3)填写赵斌同学的管理信息系统课程的成绩

UPDATE SC SET Grade= 85

WHERE Sno='20100010'AND Cno='3'

(4)将计算机科学系全体学生的成绩加5分

UPDATE sc SET Grade=Grade+ 5

WHERE'CS'=(select Sdept from student where student.Sno=sc.Sno);

(5)请自己完成如下操作

●将刘晨同学的2号课程成绩修改为80

●将“20100021”同学的学号修改为“20100025”

(6)检查数据是否修改

3. 删除数据

(1)删除学号为201000022的学生记录

DELETE FROM Student WHERE Sno='20100022'

(2)删除学号20100001学生的1号课程选课记录

将选课信息复制到一个临时表tmpSC中:

SELECT*INTO tmpSC FROM SC

在tmpSC中执行删除操作:

DELETE FROM tmpSC WHERE Sno='20100001'and Cno='1'

(3)删除临时表中20100002学生的全部选课记录

请自己完成该操作。

(4)删除计算机科学系所有学生的选课记录

DELETE FROM tmpSC WHERE'CS'=(select Sdept from student where student.Sno=tmpSC.Sno);

(5)删除全部选课记录

DELETE FROM tmpSC

(6)检查数据是否删除

3.3 数据查询操作

完成如下查询操作:

1.单表查询

(1)按指定目标列查询

●查询学生的详细记录:

SELECT*FROM Student;

●查询学生的学号、姓名和年龄

SELECT Sno,Sname,Sage FROM Student;

(2)目标列包含表达式的查询

●查询全体学生的姓名、出生年份和所有系,要求用小写字母表示所有系名。

SELECT Sname,'Year of Birth: ',2004-Sage,LOWER(Sdept) FROM Student;

(3)查询结果集中修改列名称

●查询全体学生的姓名、出生年份和所有系,要求用小写字母表示所有系名。

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

(4)取消重复行

●查询选修了课程的学生学号:比较ALL和DISTINCT的区别

SELECT Sno FROM SC;

SELECT DISTINCT Sno FROM SC;

(5)简单条件查询

●查询计算机科学系全体学生的名单

SELECT Sname FROM Student WHERE Sdept='CS';

(6)按范围查询

●查询年龄在20~23岁之间的学生的姓名、系别和年龄

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

(7)查询属性值属于指定集合的行

●查询信息系(IS)、数学系(MA)和计算机科学系(CS)学生的姓名和性别

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

(8)模糊查询

●查询所有姓刘学生的姓名、学号和性别

SELECT Sname,Sno,Ssex FROM Student WHERE Sname LIKE'刘%'

(9)查询空值

●查询缺少成绩的学生的学号和相应的课程号

SELECT Sno,Cno FROM sc WHERE Grade is null;

(10)多重条件查询

●查询计算机科学系年龄在岁以下的学生姓名

SELECT Sname FROM student WHERE Sdept='CS'and Sage<20;

(11)结果集排序

●查询全体学生情况,查询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列

SELECT*FROM Student ORDER BY Sdept,Sage DESC;

(12)完成下列查询

●查询学生基本信息,结果集属性名使用汉字

●查询信息系且年龄大于23岁同学的学号和姓名

●查询年龄是17、18、20、23岁同学的学号、姓名、年龄和所在系

●查询年龄不在21~24岁之间的学生的姓名、系别和年龄

2.分组统计

(1)聚集函数的使用

●查询学生总人数

SELECT COUNT(*)FROM Student;

●查询选修了课程的学生人数

SELECT COUNT(DISTINCT Sno)FROM SC

●查询最高分

SELECT MAX(Grade)FROM SC

(2)聚集函数作用于部分行

●统计2号课程的总分、均分和最高分

SELECT SUM(grade)总分,AVG(grade)均分,MAX(grade)最高分

FROM sc WHERE Cno='2'

(3)分组统计

●统计各门课程的选课人数、均分和最高分

select cno课程号,count(*)人数,AVG(grade)均分,MAX(grade)最高分from sc group by Cno

●统计均分大于90的课程

select cno课程号,count(*)人数,AVG(grade)均分,MAX(grade)最高分from sc group by Cno

having AVG(grade)> 90

(4)完成下面的查询

●统计每个同学的学号、选课数、平均成绩和最高成绩

●统计每个班的每门课的选课人数、平均成绩和最高成绩

3. 连接查询

(1)在WHERE中指定连接条件

●查询每个参加选课的学生信息及其选修课程的情况

SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade

FROM Student,SC

WHERE Student.Sno=SC.Sno

●查询每一门课的间接先修课

SELECT*FROM course first,course second

WHERE first.Cpno=https://www.360docs.net/doc/6211152885.html,o;

SELECT https://www.360docs.net/doc/6211152885.html,o,second.Cpno FROM course first,course second

WHERE first.Cpno=https://www.360docs.net/doc/6211152885.html,o;

(2)在FROM中指定连接条件

●查询每个参加选课的学生信息及其选修课程的情况

SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade

FROM Student JOIN SC ON (Student.Sno=SC.Sno)

(3)使用外连接查询

●查询每个学生信息及其选修课程的情况

SELECT Student.Sno,Sname,Ssex,Sage,Sdept,Cno,Grade

FROM Student LEFT OUTER JOIN SC ON (Student.Sno=SC.Sno) (4)复合条件连接查询

●查询选修号课程且成绩在分以上的所有学生

SELECT Student.Sno,Sname

FROM Student join SC ON (Student.Sno=SC.Sno)/* 连接条件*/

WHERE https://www.360docs.net/doc/6211152885.html,o='2'AND SC.Grade> 90;/* 过滤条件*/

(5)多表查询

●查询每个学生的学号、姓名、选修的课程名及成绩

SELECT Student.Sno,Sname,Cname,Grade

FROM Student,SC,Course

WHERE Student.Sno=SC.Sno AND https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o;

(6)完成下列查询

●查询选修了2号课程的同学的学号和姓名

●查询各门课程的课程号、课程名称以及选课学生的学号

●查询选修了数据库系统原理课程的同学的学号和姓名和成绩

4. 嵌套查询

(1)由In引出的子查询

●查询与“刘晨”在同一个系学习的学生

SELECT Sno,Sname,Sdept FROM Student

WHERE Sdept IN(SELECT Sdept FROM Student WHERE Sname='刘晨');

(2)由比较运算符引出的子查询

●找出每个学生超过他选修课程平均成绩的课程号。

SELECT Sno,Cno FROM SC x

WHERE Grade>=(SELECT AVG(Grade)FROM SC y

WHERE y.Sno=x.Sno);

(3)带修饰符的比较运算符引出的子查询

●查询其他系中比计算机科学系所有学生年龄都小的学生姓名及年龄。

SELECT Sname,Sage FROM Student

WHERE Sage

AND Sdept<>'CS';

(4)由EXISTS引出的子查询

●查询所有选修了1号课程的学生姓名

SELECT Sname FROM Student

WHERE EXISTS (SELECT*FROM SC WHERE Sno=Student.Sno AND Cno='1') 5. 集合查询

(1)集合并

●查询计算机科学系的学生及年龄不大于19岁的学生

SELECT*FROM Student WHERE Sdept='CS'

UNION

SELECT*FROM Student WHERE Sage<=19

(2)集合交

●查询计算机科学系且年龄不大于19岁的学生

SELECT*FROM Student WHERE Sdept='CS'

INTERSECT

SELECT*FROM Student WHERE Sage<=19

(3)集合差

●查询计算机科学系且年龄大于19岁的学生

SELECT*FROM Student WHERE Sdept='CS'

EXCEPT

SELECT*FROM Student WHERE Sage<=19;

3.4 视图操作

建立视图并基于视图进行查询:

1. 创建视图

(1)建立学生基本信息视图

CREATE VIEW Student_VIEW(学号,姓名,性别,年龄,系,班级) AS

SELECT Sno,Sname,Ssex,Sage,Sdept,Sclass

FROM Student;

(2)建立学生均分视图

CREATE VIEW S_G(Sno,Gavg)

AS

SELECT Sno,avg(Grade)

FROM SC GROUP BY Sno;

(3)建立选课信息视图

CREATE VIEW XK_VIEW

AS

SELECT Student.*,Course.*,Grade

FROM Student,SC,Course

WHERE Student.Sno=SC.Sno AND https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o;

2. 视图查询

(1)查询学生基本信息

SELECT*FROM Student_VIEW

(2)找出每个学生超过他选修课程平均成绩的课程号

SELECT SC.Sno,Cno,grade

FROM SC,S_G

WHERE SC.Sno=S_G.Sno and Grade>=S_G.Gavg (3)查询每个学生的学号、姓名、选修的课程名及成绩SELECT Sno,Sname,Cname,Grade

FROM XK_VIEW

(4)比较使用视图查询和直接从基表查询的优点

数据库实验3答案

实验三:交互式SQL语句的使用 1、实验目的 (1)掌握数据库对象的操作过程,包括创建、修改、删除 (2)熟悉表的各种操作,包括插入、修改、删除、查询 (3)熟练掌握常用SQL语句的基本语法 2、实验平台 使用SQL Server提供的Microsoft SQL Server Management Studio工具,交互式使用SQL语句。 3 实验容及要求 选择如下一个应用背景之一: ●学生选课系统 ●习题3、4、和5中使用的数据库 ●其它你熟悉的应用 (1)建立一个数据库和相关的表、索引、视图等数据库对象,练习对表、索引和视图的各种操作。 (2)要求认真进行实验,记录各实验用例及执行结果。 (3)深入了解各个操作的功能。 实验要求包括如下方面的容: 3.1 数据定义 1.基本表的创建、修改及删除 2.索引的创建 3.视图的创建 3.2 数据操作 完成各类更新操作包括: 1.插入数据

2.修改数据 3. 删除数据 3.3 数据查询操作 完成各类查询操作 1.单表查询 2.分组统计 3. 连接查询 4. 嵌套查询 5. 集合查询 3.4 数据操作 1.创建视图 2.视图查询 参考示例: 建立一个学生选课数据库,练习对表、视图和索引等数据库对象的各种操作。 一、数据定义 创建学生选课数据库ST,包括三个基本表,其中Student表保存学生基本信息,Course表保存课程信息,SC表保存学生选课信息,其结构如下表: 表1. Student表结构 表2. Course表结构

表3. SC表结构 1.创建、修改及删除基本表 (1)创建Student表 CREATE TABLE Student (Sno CHAR(8)PRIMARY KEY, Sname CHAR(8), Ssex CHAR(2)NOT NULL, Sage INT, Sdept CHAR(20) ); (2)创建Course表 CREATE TABLE Course (Cno CHAR(4)PRIMARY KEY, Cname CHAR(40)NOT NULL, Cpno CHAR(4), Ccredit SMALLINT, ); (3)创建SC表 CREATE TABLE SC (Sno CHAR(8)FOREIGN KEY (Sno)REFERENCES Student(Sno), Cno CHAR(4), Grade SMALLINT, ); (4)创建员工表Employee

数据库实验四作业及答案

实验4数据查询 一、实验目的 1.掌握使用Transact-SQL的SELECT语句进行基本查询的方法。 2.掌握使用SELECT语句进行条件查询的方法。 3.掌握嵌套查询的方法。 4.掌握多表查询的方法。 5.掌握SELECT语句的GROUP BY和ORDER BY子句的作业和使用方法。 6.掌握联合查询的操作方法。 7.掌握数据更新语句INSERT INTO、UPDATE、DELETE的使用方法。 二、实验准备 1.了解SELECT语句的基本语法格式和执行方法。 2.了解嵌套查询的表示方法。 3.了解UNION运算符的用法。 4.了解SELECT语句的GROUP BY和ORDER BY子句的作用。 5.了解IN、JOIN等子查询的格式。 6.了解INSERT INTO、UPDATE、DELETE的格式与作用。 三、实验内容及步骤 0. 创建studentsdb数据库及其相应表,并录入数据。 启动查询分析器,运行下面链接的代码即可。 创建数据库代码 1.在studentsdb数据库中,使用下列SQL语句将输出什么? (1)SELECT COUNT(*) FROM grade (2)SELECT SUBSTRING(姓名,1,2) FROM student_info (3)SELECT UPPER('kelly')

(4)SELECT Replicate('kelly',3) (5)SELECT SQRT(分数) FROM grade WHERE 分数>=85 (6)SELECT 2,3,POWER(2,3) (7)SELECT YEAR(GETDATE()),MONTH(GETDATE()),DAY(GETDATE()) 2.在studentsdb数据库中使用SELECT语句进行基本查询。 (1)在student_info表中,查询每个学生的学号、姓名、出生日期信息。 SELECT*FROM student_info (2)查询学号为0002的学生的姓名和家庭住址。 SELECT姓名,家庭住址FROM student_info WHERE学号=0002 (3)找出所有男同学的学号和姓名。 SELECT学号,姓名FROM student_info

数据库实验1-6参考答案

实验一SQL Server使用初步 一、实验目的 1、熟悉SQL Server2000的组成及基本功能。 2、掌握SQL Server2000的登录及注册。 3、掌握SQL Server2000企业管理器的使用方法。 4、熟悉查询分析器的基本使用。 二、实验预习 1、什么是数据库管理系统DBMS?你所知道的DBMS有哪些? 答:DBMS是位于用户和操作系统之间的一层数据管理软件。常见的DBMS主要有:Oracle、db2、SQL Server、MySQL、PostgreSQL、SQLite、Firebird等等。 2、SQL Server 2000(2005)的安装步骤? 答:以企业版安装为例,步骤为: 将企业版安装光盘插入光驱后,出现以下提示框。请选择“安装 SQL Server 2000 组件” 出现下面对话框后,选择 "安装数据库服务器" 。 选择 "下一步",然后选择 "本地计算机" 进行安装。 在 "安装选择" 窗口,选择 "创建新的SQL Server实例..."。对于初次安装的用户,应选用这一安装模式,不需要使用 "高级选项" 进行安装。 "高级选项" 中的内容均可在安装完成后进行调整。 在 "用户信息" 窗口,输入用户信息,并接受软件许可证协议。 在“安装定义”窗口,选择“服务器和客户端工具”选项进行安装。 在“实例名”窗口,选择“默认”的实例名称。 在“安装类型”窗口,选择“典型”安装选项,并指定“目的文件夹”。 在 "服务账号" 窗口,请选择 "对每个服务使用统一账户..." 的选项。 在 "身份验证模式" 窗口,选择 "混合模式..." 选项,并设置管理员"sa"账号的密码。 最后按“下一步”即可完成安装。 检测安装:如果安装成功,应该能成功启动SQL Server,并且能和SQL Server 客户端连接上。 可以通过服务管理器来进行启动。

数据库实验题目和答案

按照如下方式重新定义四张表: 定义新的books表,其所拥有的属性与属性类型与原有的books表一致 以列级完整性的方式定义属性bookId为主码,同时在定义的时候必须提供约束名 定义属性category为”非空” ,同时在定义的时候必须提供约束名 create table Books( bookId number(9,0) constraint BooksKey primary key, title varchar(80), author varchar(40), year integer, category varchar(15) constraint B1 not null ); commit; 定义新的customers表,其所拥有的属性与属性类型与原有的customers表一致 以表级完整性的方式定义属性cid为主码 以列级完整性的方式定义属性cname为”唯一”,同时在定义的时候必须提供约束名 create table Customers ( cid number(9,0), cname char(40) constraint C1 unique, age integer, primary key(cid) ); commit; 定义新的purchases表,其所拥有的属性与属性类型与原有的purchases表一致 定义属性cid与bookId为主码,同时在定义的时候必须提供约束名 以列级完整性的方式定义属性bookId为外码,它参照Books表的主码,同时在定义的时候必须提供约束名。当删除Books表中的某一本书时,级联删 除与它相关的购买记录 以表级完整性的方式定义属性cid为外码,它参照customers表,同时在定义的时候必须提供约束名。当删除customers表中的某个顾客时,如果存在 与该客户相关的购买记录,拒绝删除。 create table Purchases( cid number(9,0), bookId number(9,0)

同济大学数据库实验5答案

create proc procA as select* from student exec proca create proc procB @_year char(4) as select* from student where year(birthday )=@_year declare @_year char(4) set @_year ='1994' exec procB@_year create proc procf @_Snum char(30) as select s.snum ,avg(score)as平均成绩,count(https://www.360docs.net/doc/6211152885.html,um)as选秀门数,sum(1-score/60)as不及格门数 from student s,course c,sc,sections st where s.snum =sc.snum and sc.secnum =st.secnum and https://www.360docs.net/doc/6211152885.html,um =https://www.360docs.net/doc/6211152885.html,um and S.Snum =@_Snum group by S.Snum DECLARE @_SUNM char(30) set @_SUNM ='s001' exec procf@_sunm CREATE PROC Procd @_snum char(4),@_avg int out,@_selected_course int out,@_failed_course int out AS SELECT @_avg=AVG(score),@_selected_course=COUNT(cnum),@_failed_course=sum(1-score/60) FROM sc JOIN sections ON sc.secnum =sections.secnum WHERE snum=@_snum

sql 数据库 实验3答案

实验三:创建及管理数据表 1、创建表 依据数据表的结构创建相对应的数据表,表结构如下所示; 学生信息表(student ) CREATE (sno char (9) PRIMARY KEY , sname char (8) NOT NULL, ssex char (2), sage int , sdept varchar (20) ) 课程信息表(course ) CREATE (cno char (4) PRIMARY KEY , cname varchar (20) NOT NULL, cpno char (4), ccredit int ) 选课信息表(sc )

CREATE TABLE sc (sno char(9), cno char(4), grade int, Constraint PK_sno PRIMARY KEY(sno,cno)) 2.修改表结构 1)在表student中增加新字段“班级名称(sclass)”字符类型为varchar(10); use student ALTER TABLE student Add sclass nvarchar(10) 2)在表student中删除字段“班级名称(sclass)”; use student ALTER TABLE student Drop column sclass 3)修改表student中字段名为“sname”的字段长度由原来的6改为8; use student ALTER TABLE student ALTER COLUMN sname char(8) 4)修改表student中ssex字段默认值为‘男’; use student ALTER TABLE student add default'男'for ssex 5)修改表course中cname字段为强制唯一性字段; use student ALTER TABLE course Add constraint ix_course unique (cname) 6)修改表sc中grade字段的值域为0-100; use student ALTER TABLE sc Add constraint CK_grade CHECK(grade between 0 and 100) 7)删除数据表course的唯一性约束; use student ALTER TABLE course drop ix_course

数据库实验五题目答案

实验五 实验5.1 数据查询 1)要求 以School数据库为例,在该数据库中存在四表格,分别为: ●表STUDENTS(sid, sname, email, grade); ●表TEACHERS(tid, tname, email, salary); ●表COURSES(cid, cname, hour); ●表CHOICES(no, sid, tid, cid, score) 在数据库中,存在这样的关系:学生可以选择课程,一个课程对应一个教师。在表CHOICES中保存学生的选课记录。 按以下要求对数据库进行查询操作: (1)查询年级为2001的所有学生的名称并按编号升序排列。 程序:Select sname from students where grade='2001' order by sid asc; (2)查询学生的选课成绩合格的课程成绩。 程序:Select score from choices where score>'59';

(3)查询课时是48或60的课程的名称。 程序:select cname from courses where hour='48'or hour='60'; (4)查询所有课程名称中含有data的课程编号。 程序:select cid from courses where cname like'%data%';

(5)查询所有选课记录的课程号(不重复显示)。 程序:select distinct cid from choices; (6)统计所有教师的平均工资。 程序:select avg(salary) from teachers;

数据库实验四(含答案)

实验四使用SQL语句创建和删除数据库、表 一. 实验目的: 1、了解SQL Server 2005数据库的逻辑结构和物理结构。 2、掌握使用SQL 语句创建和删除数据库。 3、学会使用T-SQL语句创建表。 二. 实验准备 1.明确能够创建数据库的用户必须是系统管理员,或是被授权使用CREATE DATABASE语句的用户。 2.了解用SQL语句创建和删除数据库的基本语法。 3.是用查询分析器,完成用SQL语句创建和删除基本表。 三. 实验要求 1、熟练使用查询分析器进行数据库的创建和删除操作。 2、用查询分析器,完成用SQL语句创建和删除基本表。 3、完成实验报告。 四. 实验内容 一、数据库 1.以下是创建数据库userdb1的SQL语句, create database userdb1 on (name=userdb4_data,--数据文件的逻辑名称,注意不能与日志逻辑同名 filename='g:\xygl\userdb4.mdf' ,--物理名称,注意路径必须存在 size=5,--数据初始长度为5M maxsize=10,--最大长度为10M filegrowth=1)--数据文件每次增长1M log on ( name=userdb4_log, filename='g:\xygl\userdb4.ldf ' , size=2 , maxsize=5 , filegrowth=1) 运行上诉语句建立数据库userdb1

句,并建立“学生信息”数据库.(.mdf的名字可以修改) 3.数据库的修改(alter database 数据库名add file),将一个大小为10MB 的数据文件mrkj添加到userdb1的数据库中,该数据文件的大小为10MB,最大的文件大小为100MB,增长速度为2MB,物理地址与原有的mdf,ldf文件放在一起。 alter database 数据库名 add file() 注括号内格式同下: ( name=userdb4_log, filename='g:\xygl\userdb4.ldf ' , size=2 , maxsize=5 ,

数据库试验答案

计算机与信息学院 数据库实验报告 专业班级 学生姓名及学号 课程教学班号 任课教师 实验指导教师 实验地点 2012 ~2013 学年第二学期

实验1 使用向导创建和删除数据库 一、实验目的 1.熟悉SQL Server 中SQL Server Management Studio的环境 2.了解SQL Server 数据库的逻辑结构和物理结构 3.掌握使用向导创建和删除数据库的方法 二、实验要求 1.熟练使用SSMS进行数据库的创建和删除操作。 2.完成实验报告。 三、实验内容 设有一学籍管理系统,其数据库名为“EDUC”。 初始大小为10MB,最大为50MB,数据库自动增长,增长方式是按5%比例增长; 日志文件初始为2MB,最大可增长到5MB,按1MB增长。 数据库的逻辑文件名为“student_data”, 物理文件名为“student_data.mdf,存放路径为“E:\sql_data”。 日志文件的逻辑文件名为“student_log”, 物理文件名为“student_log.ldf”,存放路径为“E:\sql_data”。 四、实验步骤

1.使用SQL Server Management Studio(简称SSMS)创建数据库。 (1)启动SSMS 在开始菜单中:所有程序-SQL Server 2005 -SQL Server Management Studio单击“连接”按钮,便可以进入【SQL Server Management Studio】窗口。如果身份验证选择的是“混合模式”,则要输入sa的密码。 (2)建立数据库 在“对象资源管理器”窗口,建立上述数据库EDUC。在数据库节点上右击选择新建。同时建立一个同样属性的数据库EDUC1。

数据库SQLServer-实验3答案-教

数据库SQLServer-实验3答案-教辅-教材

实验3 SQL Server数据表管理 一、实验目的 1.学会使用SQL Server管理平台和Transact-SQL语句CREATE TABLE和ALTER TABLE创建和修改表。 2.学会在SQL Server管理平台中对表进行插入、修改和删除数据操作。 3.学会使用Transact-SQL语句对表进行插入、修改和删除数据操作。 4.了解SQL Server的常用数据类型。 二、实验内容 1.启动SQL Server管理平台,在对象资源管理器中展开“studentsdb数据库文件夹。 2.在studentsdb数据库中创建数据表《学生表》、《课程表》、《成绩表》,数据结构 如图3-1、图3-2和图3-3所示。 图3-1 学生表 图3-2 课程表

图3-3 成绩表3.在SQL Server管理平台中创建《学生表》、《课程表》。 4.在SQL Server管理平台中,将《学生表》的学号列设置为主键,非空。 5.使用Transact-SQ语句CREATE TABLE在studentsdb数据库中创建《成绩表》。 6.《学生表》、《课程表》、《成绩表》中的数据如图3-4、图3-5和图3-6所示。 7.在SQL Server管理平台中为《学生表》、《课程表》、《成绩表》添加数据。

(注意:在添加数据是必须逐行输入,否则系统将会报错,显示“出错信息为:键列信息不足或不正确。更新影响到多行”,产生原因是由于相同记录所造成)。 8.使用Transact-SQL语句INSERT NTTO …V ALUES向studentsdb数据库的《成绩表》插入以下数据: 学号课程编号成绩 0004 0001 80

数据库实验答案

实验3 使用T-SQL语言完成单表查询 一、实验目的 掌握使用T-SQL语言完成单表查询 掌握常用谓词的用法 掌握where子句的用法 掌握order by 子句的用法 掌握group by 子句和having短语的用法 实验环境 Microsoft SQL Server 2000。 实验内容和要求 查询全体学生的详细信息。 查询所有课程的详细信息。 查询所有选课记录的详细信息,要结果表中的列名以中文的形式显示,分别为:学号,课程号,成绩。 查询已被学生选修了的课程的编号。 查询系别编号为“d002”的学生的姓名和性别。 查询年龄在19至21岁或者性别为“女”的学生的学号和所在系别编号。 查询系别编号为d001、d002和d003的学生的学号和姓名。 查询课程名为“C_”开头的课程名和学分。 某些学生入学后还没有确定所在的系,查询还没有确定系的学生的姓名。 查询成绩大于60分的学生的学号、课程号和成绩,并将查询结果按课程编号升序排列,同一课程的成绩按分数降序排列。 查询学校所开设的总的课程数。 计算2号课的学生成绩总和以及平均成绩,对应的列名分别为“总成绩”和“平均成绩”。 查询选修了3号课程的学生的最高分和最低分,对应的列名分别为“最高分”和“最低分”。 求各个系别的编号以及各系的人数。 查询选课人数大于等于2人的课程编号以及选课的人数。 查询学生2选修课程的总成绩对应的列名为“总成绩”,并显示出学号。 查询有2门以上课程是80分以上的学生的学号及课程数。 查询选修了1号课的学生的学号和成绩,结果按成绩降序、学号升序排列。 实验1 使用T-SQL语言建库、建表 实验2 向表中增、删、改数据 实验目的 掌握使用T-SQL建库、建表、修改表; 掌握使用T-SQL对表中数据进行插入、删除和修改。 实验环境 Microsoft SQL Server 2000。 实验内容和要求 建立数据库STDB 在数据库STDB中建立四个表:

mysql数据库实验答案

实验一创建、修改数据库和表结构 1、用create建立教学数据库的五个基本表: (1)学生表(学号,姓名,性别,年龄),student((Sno, sname,ssex,sage) ; (2)课程表(课程号,课程名,学分),Course (Cno, Cname, credit) ; (3)选课表(学号,课程号,成绩),SC (Sno,, Cno, grade ) ; (4) 教师表(教师号,姓名,性别,出生年月,系部,职称,地址), T(Tno,Tname,ssex,birthday,dept,title,address) ; (5) 工资表(教师号,基本工资,职务工资,合计),Salary(Tno,jbgz,zwgz,hj); Create Database Student default character set utf8 default COLLATE utf8_bin;

Use Student; Create Table Student( SNo c har(20) primary key, SName char(20) , SSex char(4) default '男', SAge int ) ENGINE=InnoDB; Create Table Course( CNo c har(20) primary key, CName char(20) NOT NULL,

CRedit f loat ) ENGINE=InnoDB; Create Table SC( SNo c har(20) NOT NULL, CNo c har(20) NOT NULL, Grade float, Primary Key(SNo, CNo), Foreign Key(SNo) References Student(SNo) On Delete Cascade, Foreign Key(CNo) References Course(CNo) )ENGINE=InnoD B;

数据库_实验三答案

实验3 SQL语言 一、实验目的 1、掌握SQL中运算符和表达式的使用。 2、掌握实用SQL语言查询数据库。 二、实验要求 1、所有的实验过程请严格按照实验容的步骤进行。 2、对关键步骤截屏并复制到实验报告的相应位置。 三、实验设备、环境 设备:计算机 环境:WINDOWS XP、SQL SERVER 2000中文版 四、实验原理、方法 上机操作 五、实验容 准备工作:还原学生成绩管理数据库; 注意:写SQL语句时,注意学生成绩管理数据库中表名称和字段名称的对应。 1、使用SQL查询分析器,对学生成绩管理数据库完成如下查询操作: 1)简单查询 (1)求数学系学生的学号和。 (2)求选修了课程的学生学号。

(3)求选修C1课程的学生学号和成绩,并要求对查询结果按成绩的降序排列,如果成绩相同则按学号的升序排列。 (4)求选修课程0001且成绩在80~90之间的学生学号和成绩,并将成绩乘以系数0.8输出。 (5)求数学系或计算机应用系姓王的学生的信息。 (6)求缺少了成绩的学生的学号和课程号。

2)连接查询 (1)查询每个学生的情况以及他(她)所选修的课程。 (2)求学生的学号、、选修的课程名及成绩。 (3)求选修0001课程且成绩为90分以上的学生学号、及成绩。

3)嵌套查询 (1)求选修了0003的学生学号和。 (2)求0001课程的成绩高于王军的学生的学号和成绩。

(3)求其他系中比计算机系某一学生年龄小的学生。 4)使用分组和函数查询 (1)求学生的总人数。 (2)求选修了课程的学生人数。

(3)求课程和选修0001的人数。 (4)求选修课超过3门课的学生学号。

数据库实验5答案

实验五:数据库综合查询 一、实验目的 1.掌握SELECT语句的基本语法和查询条件表示方法; 2.掌握查询条件种类和表示方法; 3.掌握连接查询的表示及使用; 4.掌握嵌套查询的表示及使用; 5.了解集合查询的表示及使用。 二、实验环境 已安装SQL Server企业版的计算机(120台); 具有局域网环境,有固定IP; 三、实验学时 2学时 四、实验要求 1.了解SELECT语句的基本语法格式和执行方法; 2.了解连接查询的表示及使用; 3.了解嵌套查询的表示及使用; 4.了解集合查询的表示及使用; 5.完成实验报告; 五、实验内容及步骤 1.利用Transact-SQL嵌套语句实现下列数据查询操作。 1) 查询选修了计算机体系结构的学生的基本信息。 select*from student where Sno in(select Sno from course where Cno in(select Cno from sc where Cname='计算机体系结构')) 2) 查询年龄比李勇小的学生的学号和成绩。 select a.sno,grade from student a,course where a.sno=course.sno and sage<(select sage from student where sname='李勇') 3) 查询其他系中比系编号为‘D1’的学生中年龄最小者要大的学生的信息。select*from student where dnum<>'D1'AND SAGE>(select min(sage)from student where dnum='D1') 4) 查询其他系中比系编号为‘D3’的学生年龄都大的学生的姓名。 select*from student where dnum<>'D3'AND SAGE>all(select sage from student where dnum='D3')

数据库实验三作业及答案.docx

实验3 SQL Server 数据表的管理 一、实验目的 1.学会使用企业管理器和Transact-SQL语句CREATE TABLE和ALTER TABLE创建和修改表。 2.学会在企业管理器中对表进行插入、修改和删除数据操作。 3.学会使用Transact-SQL语句对表进行插入、修改和删除数据操作。 4.了解SQL Server的常用数据类型。 二、实验准备 1.了解在企业管理器中实现表数据的操作,如插入、修改和删除等。 2.掌握用Transact-SQL语句对表数据进行插入(INSERT)、修改(UPDATE)和删除(DELETE和TRANCATE TABLE)操作。 三、实验内容及步骤 1.启动企业管理器,展开studentsdb数据库文件夹。 2.在studentsdb数据库中包含有数据表student_info、curriculum、grade,这些表的数据结构如图1-2、图1-3和图1-4所示。 图1-2 学生基本情况表student_info 图1-3 课程信息表curriculum 图1-4 学生成绩表grade 3.在企业管理器中创建student_info、curriculum表。 4.在企业管理器中,将student_info表的学号列设置为主键,非空。 5.使用Transact-SQL语句CREATE TABLE在studentsdb数据库中创建grade表。 CREATE TABLE grade (学号varchar(4), 课程编号varchar(4), 分数decimal(5,0) ) 6.student_info、curriculum、grade表中的数据如图1-5、图1-6和图1-7所示。 图1-5 student_info的数据

数据库管理系统实验报告含答案

xxxx大学《数据库管理系统》课程实验报告 班级: _______姓名:实验时间:年月日指导教师:_______ 一、实验目的 1、通过实验,使学生全面了解最新数据库管理系统的基本内容、基本原理。 2、牢固掌握SQL SERVER的功能操作和Transact-SQL语言。 3、紧密联系实际,学会分析,解决实际问题。学生通过小组项目设计,能够运用最新数据库管理系统于管理信息系统、企业资源计划、供应链管理系统、客户关系管理系统、电子商务系统、决策支持系统、智能信息系统中等。 二、实验内容 1.导入实验用示例数据库: f:\教学库.mdf f:\教学库_log.ldf f:\仓库库存.mdf f:\仓库库存_log.ldf 1.1 将数据库导入 在SqlServer 2005 导入已有的数据库(*.mdf)文件,在SQL Server Management Studio 里连接上数据库后,选择新建查询,然后执行语句 EXEC sp_attach_db @dbname = '教学库', @ = 'f:\教学库.mdf', @ = 'f:\教学库_log.ldf' go use [教学库] EXEC sp_changedbowner 'sa' go EXEC sp_attach_db @dbname = '仓库库存', @ = 'f:\仓库库存.mdf',

@ = 'f:\仓库库存_log.ldf' go use [仓库库存] EXEC sp_changedbowner 'sa' go 1.2 可能出现问题 附加数据库出现“无法打开物理文件"X.mdf"。操作系统错误5:"5(拒绝访问。)"。(Microsoft SQL Server,错误: 5120)”。 解决:找到要附加的.mdf文件-->右键-->属性-->安全-->选择当前用户-->编辑-->完全控制。对.log文件进行相同的处理。 2.删除创建的数据库,使用T-SQL语句再次创建该数据库,主文件和日志文件的文件名同上,要求:仓库库存_data最大尺寸为无限大,增长速度为20%,日志文件初始大小为2MB,最大尺寸为5MB,增长速度为1MB。 CREATE DATABASE仓库库存 (NAME = '仓库库存_data', = 'F:\仓库库存_data.MDF' , SIZE = 10MB, = 20%) LOG ON (NAME ='仓库库存_log', = 'F:\仓库库存_log. LDF', SIZE = 2MB, MAXSIZE = 5MB, = 1MB) 2.1 在数据库“仓库库存”中完成下列操作。 (1)创建“商品”表,表结构如表1: (2)创建“仓库”表,表结构如表2: 表2 仓库表

数据库实验四答案

数据库实验四答案 --实验四-- --1.定义“IS”系学生基本情况视图V_IS 并查询结果; create view V_IS as select * from S where Sdept='IS' with check option; select * from V_IS; --2.将S,C,SC表中学生的学号,姓名,课程号,课程名,成绩定义为视图V_S_C_G并查询结果; create view V_S_C_G as select S.Sno,Sname,https://www.360docs.net/doc/6211152885.html,o,Cname from S,C,SC where S.Sno=SC.Sno and https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o; select * from V_S_C_G; --3.将各系学生人数,平均年龄定义为视图V_NUM_AVG并查询结果; create view V_NUM_AVG as select count(Sno) DeptNum ,avg(Sage) DeptAvgAge,Sdept from S group by Sdept; select * from V_NUM_AVG; --4.定义一个反映学生出生年份的视图V_YEAR并查询结果; create view V_YEAR as select Sno,2012-Sage birthday from S;

select * from V_YEAR; --5.将各位学生选修课程的门数及平均成绩定义为视图V_AVG_S_G并查询结果; create view V_AVG_S_G as select SC.Sno,count(https://www.360docs.net/doc/6211152885.html,o) CountCno,avg(Grade) AvgGrade from S,C,SC where S.Sno=SC.Sno and https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o group by SC.Sno; select * from V_AVG_S_G; --6.将各门课程的选修人数及平均成绩定义为视图V_AVG_C_G并查询结果; create view V_AVG_C_G as select count(SC.Sno) Cnum,avg(Grade) AvgGrade from S,C,SC where S.Sno=SC.Sno and https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o group by https://www.360docs.net/doc/6211152885.html,o; select * from V_AVG_C_G; --7.查询平均成绩为90分以上的学生学号、姓名和成绩; select SC.Sno,Sname,avg(Grade) AvgGrade from S,SC where S.Sno=SC.Sno group by SC.Sno,Sname having avg(Grade) >90; --8.查询各课成绩均大于平均成绩的学生学号、姓名、课程和成绩;create view V_AVG as select https://www.360docs.net/doc/6211152885.html,o,avg(Grade) AvgGrade from C,SC where https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o group by https://www.360docs.net/doc/6211152885.html,o; select distinct S.Sno,Sname,https://www.360docs.net/doc/6211152885.html,o,Grade

SQL数据库上机实验题目和答案

试用SQL的查询语句表达下列查询: 1.检索王丽同学所学课程的课程号和课程名。 select Cno ,Cname from c where Cno in (select cno from sc where sno in (select sno from s where sname='王丽' )) 2.检索年龄大于23岁的男学生的学号和姓名。 select sno,sname from s where sex='男' and age>23 3.检索‘c01’课程中一门课程的女学生姓名 select sname from s where sex='女' and sno in (select sno from sc where cno='c01') 4.检索s01同学不学的课程的课程号。 select cno from c where cno not in (select cno from sc where sno ='s01') 5.检索至少选修两门课程的学生学号。 select sc.sno from s,sc where s.sno=sc.sno group by sc.sno having count(https://www.360docs.net/doc/6211152885.html,o)>=2 6.每个学生选修的课程门数。 解法一: select so.sno sno,https://www.360docs.net/doc/6211152885.html,ount,s.sname from(select sc.sno sno,count(sc.sno) ccount from sc,s where s.sno=sc.sno group by sc.sno ) so,s where s.sno=so.sno 解法二: select sc.sno sno,s.sname,count(sc.sno) ccount from sc,s where s.sno=sc.sno group by sc.sno,sname

数据库实验及其答案

《数据库系统概论》实验报告书 专业班级 学号 姓名 指导教师 安徽工业大学计算机学院

实验一:数据定义/数据操纵语言 [ 实验日期 ] 2011 年 4 月 10 日 [ 实验目的 ] 熟悉SQL SERVER上机环境;熟练掌握和使用DDL语言,建立、修改和删除数据库表;熟练掌握和使用DML语言,对数据进行增加、修改和删除操作。 [ 实验内容 ] 1.先建立数据库:STUDENT 用两种方式建立:在查询分析器中以DDL语言方式建立.步骤为:先在指定的地方建立放置数据库文件的文件夹(如学生数据库),然后将建立的数据库文件放到指定的文件夹中. 2.SQL数据定义语句: 例1-1: (建立数据库表) 建立教学数据库的四个数据库表,其中Student表中不包含SSEX(C,2) 字段,Sname 字段为Sname(C,8)且可为空。 create table Student(SNO char(5) primary key,SNAME char(8) NULL,SDEPT char(2),SCLASS char(2),SAGE smallint) create table Course(CNO char(3) primary key,CNAME char(16),CTIME smallint) create table Teach(TNAME CHAR(8),TSEX CHAR(2),CNO CHAR(3),TDATE smalldatetime,TDEPT CHAR(2)) create table Score (sno char(5),cno char(3),Score float); 例1-2: (修改数据库表) 在Student表中增加SSEX(C,2) 字段。 alter table student add SSEX char(2) 例1-3: (修改数据库表) 将Student表中把Sname 字段修改为Sname(C,10)且为非空。 alter table student alter column SNAME char(10) not null 例1-4: (建立数据库表) 建立数据库表S1(SNO,SNAME,SD,SA),其字段类型定义与Student表中的相应字段(SNO,SNAME,SDEPT,SAGE)的数据类型定义相同。 create table S1(SNO char(5)primary key,SNAME char(10) not NULL,SD char(2),SA smallint) 3. SQL数据操纵语句: 例2-1: (插入数据) 按前面各表中的数据分别插入到教学数据库的四个数据库表中。 insert into Student values('96001','马小燕','CS','01','女',21); insert into Student values('96002','黎明','CS','01','男',18); insert into Student values('96003','刘东明','MA','01','男',18); insert into Student values('96004','赵志勇','IS','02','男',20); insert into Student values('97001','马蓉','MA','02','女',19); insert into Student values('97002','李成功','CS','01','男',20); insert into Student values('97003','黎明','IS','03','女',19); insert into Student values('97004','李丽','CS','02','女',19);

数据库实验及答案

实验二SQL语言的基本操作 实验目的和要求: 掌握利用SQL语句完成各种查询操作的能力。重点掌握用SELECT语句进行各种查询;掌握INSERT语句的用法。 实验内容: 用SQL语句完成一下的要求: 1.查询信息系(IS)的所有学生信息 select * from student where sdept=’is’ 2.查询选修了“数学”课的所有学生名单 Select s.sno,sname From student s,course c,sc Where s.sno=sc.sno and https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o and cname=’数学’ 3.查询至少选修了一门其直接先行课为5号课程的学生的姓名。 Select sname From student s, sc, course c Where s.sno=sc.sno and https://www.360docs.net/doc/6211152885.html,o=https://www.360docs.net/doc/6211152885.html,o and pcno=’5’ 4.查询全体学生的姓名和出生年份。 select sname,year(now())-sage as '出生年份' from student 5.查询所有姓王的学生。 select * from student where sname like '王%' 6.查询选修了3号课程的学生姓名及成绩,并按成绩降序排序。 Select sname,grade From student s, sc Where s.sno=sc.sno and https://www.360docs.net/doc/6211152885.html,o=’3’ Order by grade desc 7.查询全体学生情况,查询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列。 Select *

相关文档
最新文档