文档库 最新最全的文档下载
当前位置:文档库 › 数据库系统原理学生实验报告

数据库系统原理学生实验报告

学生实验报告

(理工类)

课程名称:数据库系统原理专业班级: 15计算机w专转本1班学生学号: 1513504069 学生姓名:蔡文豪

所属院部:计算机工程学院指导教师:王预

20 15 ——20 16 学年第 1 学期

金陵科技学院教务处制

实验报告书写要求

实验报告原则上要求学生手写,要求书写工整。若因课程特点需打印的,要遵照以下字体、字号、间距等的具体要求。纸张一律采用A4的纸张。

实验报告书写说明

实验报告中一至四项内容为必填项,包括实验目的和要求;实验仪器和设备;实验内容与过程;实验结果与分析。各院部可根据学科特点和实验具体要求增加项目。

填写注意事项

(1)细致观察,及时、准确、如实记录。

(2)准确说明,层次清晰。

(3)尽量采用专用术语来说明事物。

(4)外文、符号、公式要准确,应使用统一规定的名词和符号。

(5)应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。

实验报告批改说明

实验报告的批改要及时、认真、仔细,一律用红色笔批改。实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。

实验报告装订要求

实验批改完毕后,任课老师将每门课程的每个实验项目的实验报告以自然班为单位、按学号升序排列,装订成册,并附上一份该门课程的实验大纲。

实验项目名称:熟悉SQL Server2005环境及数据库文件管理实验学时: 2

实验地点: 1316

实验日期: 2016.3.24实验成绩:

批改教师:王预批改时间: 2016.3.27

一、实验目的和要求

1、熟悉SQL Server 2005工作环境、了解SQL Server 2005主要管理工具的用途、掌握登录SQL Server 2005的方法;

2、熟悉数据库的组成;

3、了解数据库快照的使用方法;

4、掌握创建、修改、删除数据库的方法;

5、熟悉如何查看数据库状态;

6、掌握分离数据库和附加数据库的方法。

二、实验设备、环境

设备:奔腾Ⅳ或奔腾Ⅳ以上计算机;

环境:WINDOWS 2000 SERVER或WINDOWS 2003 SERVER、SQL Server2005中文版。

三、实验步骤

1、根据题目要求熟悉SQL Server2005的各种管理工具;

2、分析题意,重点分析题目要求并给出解决方法;

3、按题目要求完成实际操作任务,并将相关文档资料保存在以自己学号命名的文件夹中;

4、提交完成的实验结果。

四、实验内容

一、熟悉SQL Server 2005管理工具

SQL Server2005系统提供了大量的管理工具,通过这些管理工具可以对系统实现快速、高效管理。主要管理工具如下:

1、SQL Server Management Studio

(1)对象资源管理器

允许查看和连接到SQL Server、分析器、集成服务器、报表服务器和SQL Mobile。一旦连接到特定的服务,可以在对象节点中查看它的组件,并且可以访问子节点对象。

(2)已注册的服务器

显示当前已注册的服务器。窗格顶部的列表,包括SQL Server、分析服务器、集成服务器、报表服务器和SQL Mobile。允许用户在特定的服务器之间快速转换。

(3)模板资源管理器

提供对查询编辑器的模板和任何用户所创建的自定义模板的快速访问。模板可以通过SQL Server Management Studio 所支持的任何脚本语言来创建。

(4)解决方案管理器

提供对现存的SQL Server、分析服务器和SQL Mobile的项目的快速访问。当项目被执行时,项目会给出连接、查询和执行的其他函数的详细信息。

2、SQL Server Business Intelligence Development Studio(商业智能)

SQL Server Business Intelligence Development Studio为开发人员提供的一种新的项目开发和管理工具。开发人员可以使用SQL Server Business Intelligence Development Studio设计端到端的商业智能解决方案。

3、SQL Server Configuration

SQL Server Configuration(配置管理器)包含了SQL Server2005服务、SQL Server2005网络配置和SQL Native Client配置3个工具,提供数据库管理人员做服务启动与停止与监控、服务器端支持的网络协议,用户用来访问SQL Server的网络相关设置等工作。

4、SQL Server外围应用配置

SQL Server外围应用配置器是SQL Server2005的新增功能,该工具是用来减少SQL Server的服务数和组件数的一种方法,以帮助保护SQL Server避免出现安全缺口。

5、Database Engine Tuning Advisor(数据库引擎的优化顾问)工具可以完成帮助用户分析工作负荷、

提出创建高效索引的建议等功能。

6、SQL Server联机丛书:主要为用户提供帮助。

7、sqlcmd:提供了在命令提示符中输入Transact-SQL语句、系统过程和脚本文件的功能。

二、熟悉数据库的组成

1、系统数据库

(1)master数据库

master数据库存储SQL Server2005系统的所有系统级信息。包括实例范围的元数据、端点、链接服务器和系统配置设置。

(2)model数据库

Model数据库用作SQL Server2005实例上创建的所有数据库的模板。在SQL Server2005中在三个方面做了重大改变,包括:扩大了最小值取之范围、兼容级别设置为90和PAGE_VERIFY数据库选项设置为CHECKSUM。

(3)msdb数据库

Msdb数据库主要被SQL Server2005代理用于进行复制、作业调度以及管理警报等活动,该数据库通常用于调度任务或排除故障。

(4)tempdb数据库

tempdb数据库是连接到SQL Server2005所有用户都可能用的全局资源,它保存所有临时表和临时存储过程。另外,它还用来满足所有的其他存储要求,例如,存储SQL Server 2005工作表。每次启动SQL Server2005时都会重新创建tempdb数据库,以便系统启动时,给数据库总是空的。断开连接时会自动删除临时表和存储过程,并在系统关闭后没有活动的连接。

(5)resource数据库

resource数据库是一个只读数据库,它包含了SQL Server2005中的所有系统对象。SQL Server系统对象在物理上持续存在于Resource数据库中,但逻辑上,他们出现在数据库的sys架构上。resource 数据库的物理文件名为Mssqlsystemresource.mdf。任意移动或重命名resource数据库文件,SQL Server2005将不能正常启动。

三、数据库存储文件

SQL Server2005数据库中有三种类型的文件来存储信息。

1、主数据文件

主数据文件包话数据库的启动信息,并指向数据库中的其他文件。用户数据和对象可存储在该文件中,也可以存储在辅助数据文件中。每个数据库只能有一个主数据文件。其扩展名为.mdf。

2、辅助数据文件

辅助数据文件是可选的。由用户定义并存储用户数据。每个数据库可以有多个辅助数据文件,其扩展名为.ndf。

3、事务日志文件

事务日志文件是用于保存恢复数据库的日志信息的。每个数据库必须至少有一个日志文件,其扩展名为.ldf。

4、文件组

文件组是将多个数据文件集合起来形成一个整体。每个文件组有一个组名。文件组分为主文件组和次文件组。一个文件只能存放在一个文件组中,一个文件组也只能为一个数据库使用。主文件组包含了所有的系统表。当建立数据库时,主文件组包含数据库文件和未指定组的其他文件。事务日志文件不包含在任何文件组中。

四、创建数据库

1、使用向导创建数据库

2、语句方式创建数据库

(1)最简单的语句创建数据库

Create database databaseName

(2)一般创建数据库的格式

CREATE DATABASE database_name

ON

< filespec > ,...n

, < filegroup > ,...n

LOG ON { < filespec > ,...n }

COLLATE collation_name

FOR LOAD | FOR ATTACH

< filespec > ::=

PRIMARY

( NAME = logical_file_name ,

FILENAME = 'os_file_name'

, SIZE = size

, MAXSIZE = { max_size | UNLIMITED }

, FILEGROWTH = growth_increment ) ,...n

< filegroup > ::=

FILEGROUP filegroup_name < filespec > ,...n

(3)示例

CREATE DATABASE Sales

ON

( NAME = Sales_dat,

FILENAME = 'c:\program files\microsoft sql server\mssql\data\saledat.mdf',

SIZE = 10,

MAXSIZE = 50,

FILEGROWTH = 5 )

LOG ON

( NAME = 'Sales_log',

FILENAME = 'c:\program files\microsoft sql server\mssql\data\salelog.ldf',

SIZE = 5MB,

MAXSIZE = 25MB,

FILEGROWTH = 5MB )

3、请按照要求用工具和SQL语句两种方法创建名为MyDB数据库。

五、维护数据库

1、修改数据库名称

(1)使用ALTER DATABASE语句

ALTER DATABASE databaseName MODIFY NAME=newdatabaseName

(2)使用存储过程

EXEC sp_dboption ‘databaseName’,‘SINGLE’,True /*首先将数据库设置为单用户模式*/ EXEC sp_renamedb ‘databaseName’, ‘newdatabaseName’ /*修改数据库名*/

EXEC sp_dboption ‘newdatabaseName’, ‘SINGLE’,False /*取消单用户模式*/

(3)从资源管理器窗口修改数据库名

2、修改数据库大小

(1)设置数据库文件为自动增长方式

(2)直接修改数据库文件的大小

(3)增加辅助数据库文件

(4)示例

CREATE DATABASE Test1 ON

(NAME = Test1dat1,

FILENAME = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\t1dat1.ndf',

SIZE = 5MB,

MAXSIZE = 100MB,

FILEGROWTH = 5MB )

GO

ALTER DATABASE Test1

ADD FILE

(NAME = Test1dat2,

FILENAME = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\t1dat2.ndf',

SIZE = 5MB,

MAXSIZE = 100MB,

FILEGROWTH = 5MB )

(5)请参照示例用SQL语句为MyDB数据库增加辅助数据库文件MyDB2,其大小为3MB,最大为10MB,按照10%增长。

3、收缩数据库

(1)设置数据库为自动收缩

(2)手动收缩数据库

(3)使用DBCC SHRINKDATABASE命令收缩数据库

该命令是一种比自动收缩数据库更加灵活的收缩数据库方式。可以对整个数据库进行收缩。

示例:DBCC SHRINKDATABASE (UserDB, 10)

/*该命令将UserDB用户数据库中的文件减小,以使UserDB中的文件有10%的可用空间。*/ (4)请使用该命令将MyDB数据库收缩到有10%的可用空间。

4、删除数据库

(1)使用管理工具

(2)使用T-SQL语句

DROP DATABASE database_name ,...n

5、分离数据库

分离数据库是指数据库从SQL Server实例上删除,但是数据文件、但事务日志文件仍然保持不变。注意:分离数据库如果出现下列情况之一,则不允许分离:

*已复制并发数据库、 *数据库中存在数据库快照、 *数据库处于未知状态。

(1)使用语句分离数据库

示例:exec sp_detach_db MyDB

(2)可以使用工具

6、附加数据库

附加数据库时,所有的数据文件(.mdf文件和.ndf文件)都必须是可用的。如果任何数据文件的路径和创建时或上次附加数据库时的路径不同,则必须指定文件的当前路径。在附加数据库的过程中,

如果没有日志文件,系统将创建一个新的日志文件。

(1)使用工具附加数据库

(2)使用SQL语句附加数据库

示例:CREATE DATABASE Sales

ON ( NAME =‘Sales_dat’,

FILENAME =‘c:\program files\microsoft sql server\mssql\data\saledat.mdf' ) LOG ON

( NAME =‘Sales_log',

FILENAME =‘c:\program files\microsoft sql server\mssql\data\salelog.ldf') FOR ATTACH

(3)请用上述两种方法将MyDB数据库附加到实例中。

五、问题解答及实验结果

1.创建数据库MyDB

create database MyDB

on(

name=MyDB_data,Filename='D:\data\My_data.mdf',size=3MB,fileGrowth=1mb)

log on

(name=MyDB_log,Filename='D:\data\MyDB_log.ldf',size=1MB,filegrowth=10%)

2.重命名数据库,改为MyDB1

先刷新

alter database MyDB Modify name=MyDB1

3.使用存储过程修改数据库名称

exec sp_dboption 'MyDB','SINGLE',True

exec sp_renamedb 'MyDB','MyDB1'

exec sp_dboption 'MyDB1','SINGLE',False

4.增加辅助数据库MyDB2

alter database MyDB1

add file(

name=MyDB2,filename='D:\data\MyDB2dat.ndf',size=3MB,Maxsize=10MB,FileGrowth=10%) 5.收缩数据库

dbcc SHRINKDATABASE (MyDB,10)

6.删除数据库

drop database MyDB

7.附加数据库

先分离数据库,并且给data权限

create database MyDB on

(name='MyDB_dat',filename='D:\data\My_data.mdf')

log on

(name='MyDB_log',filename='D:\data\MyDB_log.ldf')for ATTACH;

六、实验体会和收获

2年过去了,我又重新开始学习数据库了,这次学的是SqlServer2008,和当年的学的MySQL5.5差不多,大同小异,初步学习了如何创建数据库,删除,附加,分离等一系列基础操作,为以后的学习做好了准备。这些基础的东西很重要,以后每次实验都有可能用到,万事开头难,以后学习SQLserver一定会越来越容易。

实验项目名称:表和表数据的操作实验学时: 2

实验地点: 1316

实验日期: 2016.3.30 实验成绩:

批改教师:王预批改时间: 2016.4.4

一、实验目的和要求

1、了解表的类型及创建方法;

2、熟悉各种数据类型;

3、掌握列的各种属性;

4、掌握自定义数据类型的创建方法;

5、掌握用T-SQL语言和工具创建表的方法;

6、掌握工具和T-SQL语言插入数据的方法。

二、实验设备、环境

设备:奔腾Ⅳ或奔腾Ⅳ以上计算机;

环境:WINDOWS 2000 SERVER或WINDOWS 2003 SERVER、SQL Server2005中文版。

三、实验步骤

1、根据题目要求熟悉SQL Server2005的各种管理工具;

2、分析题意,重点分析题目要求并给出解决方法;

3、按题目要求完成实际操作任务,并将相关文档资料保存在以自己学号命名的文件夹中;

4、提交完成的实验结果。

四、实验内容

一、表的概述

1、表的概念

在关系数据库中每一个关系都体现为一张表。表是用来存储数据和操作数据的逻辑结构,关系数据库中所有的数据都表现为表的形式。

2、表的类型

在SQL Server2005中,可以把表分为4种类型,即普通表、分区表、临时表和系统表。每一种表都有其自身的作用和特点。

(1)普通表:又称为标准表,就是通常所说的数据库中存储数据的标,是最常使用的表对象,是最重要和最基本的表。

(2)分区表:分区表示将数据水平划分成多个单元的表,这些单元的表可以分散到数据库中的多个文件组里,以实现对单元中数据的并行访问。其优点在于可以方便地管理大型表,提高对这些表中数据的使用效率。

(3)临时表:临时表是临时创建的、不能永久生存的表。又可以分为本地临时表和全局临时表。本地

临时表以#打头,它们仅对当前的用户连接时可见的,当用户从SQL Serve2005实理断开连接时被删除;全局临时表以##打头,创建后任何用户都是可见,当所有引用该表的用户从SQL Server 2005中断开连接时被删除。

(4)系统表:系统表与普通表的区别在于,系统表存储了有关SQL Server 2005服务器的配置、数据库设置、用户和表对象的描述等信息。

二、列

1、列数据类型

在设计表的时候,需要知道每列字段的数据类型。SQL Server 2005系统提供了28种数据类型,主要分为七大类。

(1)精确数字类型

这些数据类型的数据可以参加各种数学运算,所有的数值都是有精度的,精度是指有效数字位数。如整数数据类型:binint、int、smalling、tinyint;位数据类型bit;货币数据类型:Money、Smallmoney等。(2)近似数字类型

在现实计算中,还有一些数据没有精确数值,如1/3,它无法用精确数字类型表示,需要由系统来定义精确到哪一位,这种类型就是近似数据类型。如:Decimal和Numeric;Float和Real等。

(3)字符数据类型

它是用来存储各种字母、数字符号和特殊符号。在使用该数据类型时,需要用用单引号或双引号括起来。SQL Server 2005主要提供了Char、Varchar、Text3中数据类型。

(4)Unicode字符数据类型

Unicode是一种在计算机上使用的字符编码。它为每一种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。SQL Server 2005主要有:Nchar、Nvarchar、Ntext三种。

(5)二进制数据类型

二进制数据类型可以用来存储二进制的数据。主要有:Binary、Varbinary、Image三种类型。

(6)日期和时间数据类型

在SQL Server2005中,日期和时间类型主要包括:datetime 和smalldatetime两种。两者区别在于其表示的日期和时间的范围不同,时间的精确度也不同。

(7)其他数据类型

SQL Server2005系统还提供了Cursor、Sql_varant、Table、Timestamp、Uniqueidentifie、XML6种特殊用途的数据类型。

2、列的其他属性

(1)NULL和NOT NULL

定义属性列时可以规定该列是否可以为空。

(2)默认值

当某个属性的值大部分的取值都是相同时,可以使用默认值来减少插入数据时的时间。

(3)IDENTITY

使用IDENTITY关键字定义的字段为标识字段,标识字段是唯一标识每条记录的特殊字段,当一条

新记录添加时,这个字段就被自动赋予一个新值。默认情况下是+1递增。

三、创建表

1、使用SQL Server Management Studio工具在MyDB数据库中创建Student和Class表。Student表的结构为:

2、使用T-SQL语言在MyDB数据库中创建再Course和Grade表,为以后的实验做准备。

四、自定义数据类型

(1)使用SQL Server Management Studio工具创建用户自定义数据类型:studentNo,char(8) (2)系统存储过程sp_addtype 创建用户自定义数据类型: courseNo,char(4)

(3)修改MyDB数据库中的各表,学号和课程号应用自定义的数据类型。

五、修改表结构

(1)使用Alter修改Student表结构,使其增加一列Department(系别)Char(12)。

(2)使用SQL Server Management Studio工具删除刚刚增加的Department。

六、插入数据

使用SQL Server Management Studio工具或insert into语句,分别向下列表格插入数据。(1)向表(Student)中插入数据

插入数据之后使用命令:Select * from Student;检查插入数据的正确性

(2)向表(Class)中插入数据

插入数据之后使用命令:Select * from Class; 检查插入数据的正确性

插入数据之后使用命令:Select * from Course; 检查插入数据的正确性

(4)向表(Grade )中插入数据

插入数据之后使用命令:Select * from Grade; 检查插入数据的正确性

七、删除表中的数据

(1)使用SQL Server Management Studio工具删除课程号为0001的选课记录。

(2)使用T-SQL语言删除Grade表中学号为19920101的数据

八、删除表格

(1)使用SQLSQL Server Management Studio工具删除Class表。

(2)使用Drop Table命令删除Grade表。

*注意在删除之前,请将数据文件拷贝一个副本,已备以后实验使用。

五、问题解答及实验结果

1.创建student表

USE MyDB

CREATE TABLE dbo.Student(

SNO char(8) COLLATE Chinese_PRC_CI_AS NOT NULL primary key,

SName varchar(50) COLLATE Chinese_PRC_CI_AS NOT NULL,

Sex char(2) COLLATE Chinese_PRC_CI_AS NOT NULL,

ClsNO char(6) COLLATE Chinese_PRC_CI_AS NOT NULL,

StuAddr varchar(20) COLLATE Chinese_PRC_CI_AS NOT NULL,

Brithday datetime NOT NULL,

Height numeric(4, 2) NOT NULL,

TotalCredit tinyint NOT NULL,)

2.新建Class表

USE MyDB

CREATE TABLE Class (

ClsNO char(6) COLLATE Chinese_PRC_CI_AS NOT NULL PRIMARY KEY ,

ClsName varchar(16) COLLATE Chinese_PRC_CI_AS NOT NULL,

Director varchar(50) COLLATE Chinese_PRC_CI_AS NOT NULL,

Speicalty varchar(30) COLLATE Chinese_PRC_CI_AS NOT NULL,

)

3.创建course表

use MyDB

create table Course(

CNO char(4)Not NULL,CName varchar(16)NOT NULL,PCNO char(4),Credit Tinyint,Primary KEY(CNO))

4.创建Grade表

use MyDB

create table Grade(

SNO char(8)Not NULL,CNO char(4)NOT NULL,Scorce Numeric(4,1),Credit Tinyint,Primary KEY(SNO,CNO))

5.插入记录,分别插入Class,Student,Grade,Course表

insert into Class values('CS01','计算机一班','王宁','计算机应用')

insert into Class values('MT04','数学四班','陈晨','数学')

insert into Class values('PH08','物理八班','葛格','物理')

insert into Student values('19920101','王军','男','CS01','下关#','1976.12.21',1.76,10)

insert into Student values('19920102','李杰','男','CS01','江边路#','1974.5.24',1.72,9)

insert into Student values('19920306','王彤','女','MT04','中央路#','1977.3.18',1.65,9)

insert into Student values('19940106','吴杪','女','PH08','莲化小区#','1979.4.8',1.60,4)

insert into Course values('0001','数学','',6)

insert into Course values('0003','计算机基础','',3)

insert into Course values('0007','物理','',4)

insert into Grade values('19920101','0001',90,6)

insert into Grade values('19920101','0007',86,4) insert into Grade values('19920102','0001',87,6) insert into Grade values('19920102','0003',76,3) insert into Grade values('19920306','0001',87,6) insert into Grade values('19920306','0003',93,3) insert into Grade values('19940106','0007',85,4) 6.添加类型

use MyDB

exec sp_addtype studentNO,'char(8)','NOT NULL'; exec sp_addtype courseNO,'char(4)','NOT NULL';

7.修改类型

use MyDB

alter table Student ADD Department char(12);

8.删除数据19920101

delete from grade where SNO='19920101'

9.删除数据库

drop table Grade

相关文档
相关文档 最新文档