数据库实验书Word文件下载.docx
《数据库实验书Word文件下载.docx》由会员分享,可在线阅读,更多相关《数据库实验书Word文件下载.docx(35页珍藏版)》请在冰豆网上搜索。
查看本地已注册的SQLServer。
搜索网络上的另一台计算机,并且注册该机上的SQLServer,注册时使用“Windows认证模式”或“用我的SQLServer账户信息自动登录”的连接方式。
从SQL企业管理器中注销网络SQLServer。
6.
打开本地服务器的属性对话框,查看以下信息:
产品名称、主机操作系统、产品的版本、操作平台、主机内存等。
7.
利用企业管理器访问系统自带的pubs数据库。
(1)
以企业管理员的身份登录到企业管理器。
(2)
在企业管理器的树形目录中找到pubs数据库并展开,查看该数据库的所有对象,如表、视图、存储过程、默认和规则等。
(3)
选择pubs数据库的“表”选项,在右窗口中将列出pubs数据库的所有表(包括系统表和用户表),选择用户表titles表,右击鼠标,弹出快捷菜单,从中选择“打开表”→“返回所有行”菜单项,打开titles表,查看其内容。
8.
利用查询分析器访问pubs数据库的表。
通过“开始”→“程序”→MicrosoftSQLServer→“查询分析器”方式运行SQLServer查询分析器,或者在企业管理器中选择“工具”→“SQL查询分析器”菜单项,运行SQLServer查询分析器。
在查询分析器窗口中,选择“查询”→“更改数据库…”菜单项,或者单击常用工具栏中的“更改数据库”下拉按钮,选择要操作的pubs数据库。
在查询分析器的编辑窗口中,输入以下代码:
SELECTtype,avg(price)
FROMtitles
WHEREroyalty=10
GROUPBYtype
(4)
选择查询分析器的“查询”→“分析”菜单项,或者单击常用工具栏上“分析查询”按钮
,查询分析器将对输入的代码进行语法分析,并由消息窗格给出分析结果报告。
(5)
选择查询分析器的“查询”→“执行”菜单项,或者单击常用工具栏上“执行查询”按钮
,SQLServer将编译窗口中的代码,并在结果窗格中显示查询结果,如图1-1所示。
实验2
SQLServer
数据库的管理
1.
了解SQLServer数据库的逻辑结构和物理结构的特点。
2.
学会使用企业管理器对数据库进行管理。
3.
学会使用Transact-SQL语句对数据库进行管理。
确定能够创建数据库的用户是系统管理员,或是被授权使用CREATEDATABASE语句的用户。
确定要创建的数据库名、所有者(即创建数据库的用户)、数据库大小(最初的大小、最大的大小、是否允许增长即增长的方式)和存储数据的文件。
了解常用的创建数据库方法。
在企业管理器中创建studentsdb数据库。
运行SQLServer管理器,启动企业管理器,展开服务器“(LOCAL)(WindowsNT)”。
右击“数据库”项,在快捷菜单中选择“新建数据库”菜单项。
在新建数据库对话框的名称文本框中输入学生管理数据库名studentsdb。
选择studentsdb数据库,在其快捷菜单中选择“属性”菜单项,查看“常规”、“数据文件”、“事务日志”、“文件组”、“选项”和“权限”页面。
打开studentsdb数据库的“属性”对话框,在“数据文件”选项卡中修改studentsdb数据文件的“分配空间”大小为2MB。
指定“最大文件大小”为5MB.在“事务日志”选项卡中修改studentsdb数据库的日志文件的大小在每次填满时自动递增5%。
启动查询分析器,在查询分析器中使用Transact-SQL语句CREATEDATABASE创建studb数据库。
然后通过系统存储过程sp_helpdb查看系统中的数据库信息。
在查询分析器中使用Transact-SQL语句ALTERDATABASE修改studb数据库的设置,指定数据文件大小为5MB,最大文件大小为20MB,自动递增大小文1MB。
在企业管理器中为studb数据库增加一个日志文件,命名为studb_Log2,大小为5MB,最大文件大小为10MB。
使用企业管理器将studb数据库的名称更改为student_db。
使用Transact-SQL语句DROPDATABASE删除student_db数据库。
9.
在企业管理器中删除studentsdb数据库。
四、
实验思考
新数据库是否包含SQLServer在主设备中生成的模型数据库内的所有对象?
实验3
数据表的管理
学会使用企业管理器和Transact-SQL语句CREATETABLE和ALTERTABLE创建和修改表。
学会在企业管理器中对表进行插入、修改和删除数据操作。
学会使用Transact-SQL语句对表进行插入、修改和删除数据操作。
了解SQLServer的常用数据类型。
了解在企业管理器中实现表数据的操作,如插入、修改和删除等。
掌握用Transact-SQL语句对表数据进行插入(INSERT)、修改(UPDATE)和删除(DELETE和TRANCATETABLE)操作。
启动企业管理器,展开studentsdb数据库文件夹。
在studentsdb数据库中包含有数据表student_info、curriculum、grade,这些表的数据结构如图1-2、图1-3和图1-4所示。
图1-2
学生基本情况表student_info
图1-3
课程信息表curriculum
图1-4
学生成绩表grade
在企业管理器中创建student_info、curriculum表。
在企业管理器中,将student_info表的学号列设置为主键,非空。
使用Transact-SQL语句CREATETABLE在studentsdb数据库中创建grade表。
student_info、curriculum、grade表中的数据如图1-5、图1-6和图1-7所示。
图1-5
student_info的数据
图1-6
curriculum的数据
图1-7
grade的数据
在企业管理器中为student_info、curriculum、grade表添加数据。
使用Transact_SQL语句INSERTINTO...VALUES向studentsdb数据库的grade表插入以下数据:
学号
课程编号
分数
0004
0001
80
使用Transact_SQL语句ALTERTABLE修改curriculum表的“课程编号”列,使之为非空。
10.
使用Transact_SQL语句ALTERTABLE修改grade表的“分数”列,使其数据类型为real。
11.
使用Transact_SQL语句ALTERTABLE修改student_info表的“姓名”列,使其列名为“学生姓名”,数据类型为archar(10),非空。
12.
分别使用企业管理器和Transact_SQL语句DELETE删除studentsdb数据库的grade表中学号为'
0004'
的成绩记录。
DELETEgradeWHERE
学号='
13.
使用Transact_SQL语句UPDATE修改studentsdb数据库的grade表中学号为'
0003'
、课程编号为'
0005'
、分数为90的成绩记录。
UPDATEgradeSET
分数=90
WHERE
and
课程编号='
14.
使用Transact_SQL语句ALTER...ADD为studentsdb数据库的grade表添加一个名为“备注”的数据列,其数据类型为VARCHAR(20)。
ALTERTABLEgradeADD
备注
VARCHAR(20)NULL
15.
分别使用企业管理器和Transact_SQL语句DROPTABLE删除studentsdb数据库中的grade表。
使用Transact-SQL语句删除在studentsdb数据库的grade表添加的“备注”数据列。
在企业管理器中,studentsdb数据库的student_info表的数据输入时,如果输入相同学号的记录将出现什么现象?
怎样避免该情况的发生?
实验4
数据查询
掌握使用Transact-SQL的SELECT语句进行基本查询的方法。
掌握使用SELECT语句进行条件查询的方法。
掌握嵌套查询的方法。
掌握多表查询的方法。
掌握SELECT语句的GROUPBY和ORDERBY子句的作业和使用方法。
掌握联合查询的操作方法。
掌握数据更新语句INSERTINTO、UPDATE、DELETE的使用方法。
了解SELECT语句的基本语法格式和执行方法。
了解嵌套查询的表示方法。
了解UNION运算符的用法。
了解SELECT语句的GROUPBY和ORDERBY子句的作用。
了解IN、JOIN等子查询的格式。
了解INSERTINTO、UPDATE、DELETE的格式与作用。
0.
创建studentsdb数据库及其相应表,并录入数据。
启动查询分析器,运行下面链接的代码即可。
创建数据库代码
在studentsdb数据库中,使用下列SQL语句将输出什么?
SELECTCOUNT(*)FROMgrade
SELECTSUBSTRING(姓名,1,2)FROMstudent_info
SELECTUPPER('
kelly'
)
SELECTReplicate('
3)
SELECTSQRT(分数)FROMgradeWHERE
分数>
=85
(6)
SELECT2,3,POWER(2,3)
(7)
SELECTYEAR(GETDATE()),MONTH(GETDATE()),DAY(GETDATE())
在studentsdb数据库中使用SELECT语句进行基本查询。
在student_info表中,查询每个学生的学号、姓名、出生日期信息。
查询学号为0002的学生的姓名和家庭住址。
找出所有男同学的学号和姓名。
使用SELECT语句进行条件查询
在grade表中查找分数在80~90分为内的学生的学号和分数。
在grade表中查询课程编号为0003的学生的平均分。
在grade表中查询学习各门课程的人数。
将学生按出生日期由大到小排序。
查询所有姓“张”的学生的学号和姓名。
SELECT
学号,姓名
FROMstudent_infoWHERE
姓名
LIKE'
张%'
嵌套查询
在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。
姓名,出生日期
FROMstudent_info
性别=
(SELECT
性别
姓名='
刘卫平'
使用IN子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。
学号,姓名,性别
WHEREstudent_info.学号
IN
学号
FROMgrade
IN('
0002'
'
))
列出学号为0001的学生的分数比0002号的学生的最低分数高的课程编号和分数。
课程编号,分数
0001'
AND
ANY
列出学号为0001的学生的分数比0002的学生的最高成绩还要高的课程编号和分数。
多表查询
查询分数在80~90范围内的学生的学号、姓名、分数。
SELECTstudent_info.学号,姓名,分数
FROMstudent_info,grade
WHEREstudent_info.学号=grade.学号
AND
分数
BETWEEN80AND90
查询学习“C语言程序设计”课程的学生的学号、姓名、分数。
INNERJOINgradeONstudent_info.学号=grade.学号
INNERJOINcurriculumON
课程名称='
C语言程序设计'
查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。
查询每个学生的所选课程的最高成绩,要求列出学号、姓名、课程名称、分数。
查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总成绩为空。
提示:
使用左外连接。
为grade表添加数据行:
学号0004、课程编号为0006、成绩为76。
查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。
使用右外连接。
使用UNION运算符将student_info表中姓“张”的学生的学号、姓名与curriculum表的课程编号、课程名称返回在一个表中,且列名为u_编号、u_名称,如图1-8所示。
图1-8
联合查询结果集
数据更新
创建totalgrade表,具有数据列:
学号、姓名、总成绩。
CREATETABLEtotalgrade
(
char(4)NOTNULL,
varchar(8)NULL,
总成绩
decimal(5,2)NULL)
使用INSERTINTO语句通过student_info表更新totalgrade表的学号、姓名列数据。
INSERTINTOtotalgrade
SELECT
学号,姓名,总成绩=0FROMstudent_info
使用UPDATE语句通过grade表更新totalgrade表的中成绩列数据,使totalgrade表中每个学生的总分成绩为grade表中该学生各成绩之和。
UPDATE
totalgradeSET
总成绩=
(SELECTSUM(分数)FROMgradeWHEREtotalgrade.学号=grade.学号)
删除totalgrade表中没有总成绩的学生记录。
查询所有没有选修课程的学生信息,返回结果包括学号、姓名、性别。
在student_info表和grade表之间实现交叉连接。
查询每个学生的所选课程的成绩,并列出学号生成分组汇总(总成绩)和明细行(各课成绩)。
使用SELECT语句的COMPUTE选项。
实验5
索引和视图
一、实验目的
学会使用企业管理器和Transact-SQL语句CREATEINDEX创建索引。
学会使用企业管理器查看索引。
学会使用企业管理器和Transact-SQL语句DROPINDEX删除索引。
掌握使用企业管理器、向导等创建、管理和删除全文索引,并使用全文引索查询信息的方法。
掌握使用企业管理器和Transact-SQL语句CREATE-VIEW创建视图的用法。
掌握系统存储过程sp_rename的用法。
掌握使用Transact-SQL语句ALTERVIEW修改视图的方法。
二、实验准备
了解聚集索引和非聚集索引的概念。
了解使用Transact-SQL语句CREATEINDEX创建索引的语法。
了解使用企业管理器创建索引的步骤。
了解Transact-SQL语句DROPINDEX删除索引的用法。
了解创建视图的Transact-SQL语句CREATEINDEX的语法格式及用法。
了解修改视图的Transact-SQL语句ALTERVIEW的语法格式。
了解视图更名的系统存储过程sp_rename的用法。
了解删除视图的Transact-SQL语句DROPVIEW的用法。
三、实验内容
1.分别使用企业管理器和Transact-SQL语句为studentsdb数据库的student_info表格和curriculum表创建主键索引。
2.使用企业管理器按curriculum表的课程编号列创建唯一性索引。
3.分别使用企业管理器和Transact-SQL语句为studentsdb数据库的grade表的“分数”字段创建一个非聚集索引,命名为grade_index。
CREATEINDEXgrade_indexONgrade(分数)
4.为studentsdb数据库的grade表的“学号”和“课程编号”字段创建一个复合唯一索引,命名为grade_id_c_ind。
CREATEUNIQUEINDEXgrade_id_c_indONgrade(学号,课程编号)
5.分别使用企业管理器和系统存储过程sp_helpindex查看grade表和student_info表上的索引信息。
sp_helpindexgrade
6.使用企业管理器的“向导”工具对grade表创建一个聚集索引和唯一索引。
7.使用系统存储过程sp_rename将引索grade_index更名为grade_ind。
sp_rename
ˊgrade.grade_indexˊ,ˊgrade_indˊ,
ˊINDEXˊ
分别使用企业管理器和Transact-SQL语句DROPINDEX删除索引grade_ind。
再次使用系统存储过程sp_helpindex查看grade表上的索引信息。
DROPINDEXgrade.grade_ind
分别使用企业管理器和系统存储过程sp_fulltext_database为studentsdb数据库启用全文索引。
分别使用企业管理器和系统存储过程sp_fulltext_catalog为studentsdb数据库建立全文目录,命名为FT_stu。
为student_info表建立全文索引数据元。
executesp_fulltext_catalog
ˊFT_stuˊ,ˊcreateˊ
execsp_fulltext_tableˊstudent_infoˊ,ˊcreateˊ,ˊFT_stuˊ,ˊPK_student_infoˊ
在建立全文索引数据元之前保证已为student_info表建立了PK_student_infl索引。
为student_info表设置全文索引列名为ˊ家庭住