数据库实务实验报告酒店前台管理系统.docx
《数据库实务实验报告酒店前台管理系统.docx》由会员分享,可在线阅读,更多相关《数据库实务实验报告酒店前台管理系统.docx(37页珍藏版)》请在三一办公上搜索。
1、数据库管理实务实验报告课程号:B0900980实验项目:数据库设计、创建、管理,数据库操作学号姓名马冰洁同组人学号姓名实验地点工程学院机房(文波)指导教师肖慎勇时间2012年6月评语(要求): 按时完成实验;实验内容和过程记录完整;回答问题完整、正确;实验报告的撰写认真、格式符合要求。成绩教师签字肖慎勇一、实验目的1理解并掌握数据库设计的概念、方法和步骤。2初步应用数据库设计方法。了解需求分析的内容。3重点运用ER模型进行概念设计,然后将ER模型转换为关系模型。4深入理解SQL Server 2005数据库的存储结构。5深入理解SQL Server 2005的数据类型、表对象设计与定义。6掌握
2、SQL Server 2005Management studio的应用。运用交互方式和命令方式建立数据库和表。7认识和掌握Transact-SQL 的数据库操作。8深入理解视图意义。掌握SQL Server 中创建、管理与应用视图的方法。9深入理解数据库安全的概念。10深入理解SQL Server 2005的安全体系框架。11掌握登录与服务器角色的概念、操作与应用。掌握数据库用户、固定角色、自定义角色、架构的概念、操作与应用。掌握数据库权限的概念、操作与应用。12理解事务的概念。13深入理解并掌握服务器编程的意义及方法。14能够编写各种自定义函数和存储过程。15理解触发器,并能够编写、应用触发
3、器。二、实验设备(环境)及要求PC、 Windows XP、SQL SERVER 2005三、实验内容及要求 实验项目:各小组自选的项目。通过调查、收集信息、分析,写出分析与设计报告。1. 简要的系统需求分析包括业务分析、功能需求分析、信息需求分析。试分析该系统的基本业务,计算机信息系统需要完成的基本功能、信息系统需要处理的信息。2. 概念设计设计系统的概念模型,采用ER模型。3. 逻辑设计将ER模型为关系模型,指出每个关系的主键、外键和必要的约束。4. 写出数据库的物理设计包括存储组织结构、表的结构设计等。5. T-SQL命令方式创建数据库的操作利用SQL命令创建数据库文件、表、索引、联系和
4、主键、外键等约束。(实验报告应写出实验的过程,包括必要的截图。)6. 利用T-SQL命令增加、删除、修改数据。7. 利用T-SQL命令进行数据的检索和统计根据自己设计的数据库和输入的数据,写出至少10个查询要求及对应的SQL查询命令,应该包含如下功能:投影和选择;多表连接;分组统计与HAVING;子查询;查询结果保存。8. 利用SQL命令创建视图对象根据开发的系统的需要,至少设计三个视图:基于单表的、包含多表连接的、包含统计运算的。利用SQL对视图进行查询。9. 对视图进行插入、删除、修改数据操作。体会视图与表的异同。10. 编写自定义函数。(1)编写一个自定义函数,将一个字符串作为自变量,返
5、回颠倒顺序的字符串。写出源代码。(2) 编写一个自定义函数,能够实现参数化查询的功能。自己设定函数的具体要求,然后编写出来。11. 编写利用游标进行数据处理的存储过程。并在存储过程中应用事务的概念。自己确定过程的具体要求,然后编写出来。12. 编写一个实现修改表的触发器,实现完整性控制。13. 设置服务器身份验证模式。用命令创建若干不同验证模式的登录账户。14. 将部分登录赋予服务器角色。然后撤消。15. 将部分登录映射到你的数据库中成为用户。16. 创建自定义角色、架构。17. 通过角色给用户授权。18. 直接给用户授权,验证其获得权限前后的操作差别。19. 删除用户和自定义的角色。四、回答
6、问题1你如何认识需求分析在系统开发中的地位和重要性?需求分析就是根据用户或者客户的需要来设计数据库。只有根据需求设计出的数据库才是有用的,否则整个设计过程都是在做无用功。并且在需求设计这个过程中根据具体需要设计出模型,后面的具体实现过程遵照前面设计的模型来完成,使得后面的工作能够更加具有效率。在需求分析中要严格遵守客户的需求,并且要根据需求找出最合适的方案,为后面的具体实现打下基础。需求分析是整个开发过程的第一个阶段,也是最重要的一步。2设计ER图、关系模型分别属于数据库设计的哪一阶段?设计ER图属于概念设计阶段,关系模型属于逻辑设计阶段。3主键、外键对于关系数据库的意义何在?主键是关系中能唯
7、一区分、确定不同元组的单个属性或者属性组合。外键能够保证数据库的数据的完整性和一致性,通过外键,能够将相互关联的表联系起来。4在数据库存储结构设计时要考虑哪些因素?需要综合考虑存取时间、存储空间利用率和维护代价三方面的因素。5在表设计时对于数据类型的选择和使用如何考虑?数据类型的选择首先要根据该属性的性质进行选择,如数值型,日期型等等。在确定基本类型之后,要考虑数据存取时间、取值范围、处理效率多方面的因素,选取合适的数据类型,这主要是在数值类型上的选择。6. 交互式如何实现表之间的联系?SQL命令如何实现表之间的联系?交互式:单击工具栏上的“关系”按钮,打开“外键关系”对话框,在其中设置各表间
8、关系。SQL命令:利用FOREIGN KEY REFERENCES referenced_table_name(referenced_column) ON DELETE NO ACTION|CASCADE|SET NULL|SET DEFAULT ON UPDATE NO ACTION|CASCADE|SET NULL|SET DEFAULT7如果在定义表时进行了主键、外键以及约束等完整性设置,对于数据的输入有何影响?试举例说明。 主键和外键一般不允许为空,如果没有输入值的话会报错。再比如“性别”这一字段如果开发人员已经约束了其值只能为“男”或者“女”,当使用者输入除以上两个值之外的任何值都会
9、报错。8用INSERT INTO 命令输入,如果数据与字段数量和要求不一致有什么问题?当表定义中有默认值的时候,插入记录是否可以省略该字段的数据?如果数据与字段数量和要求不一致,只有在少于并且没有写出的那个已定义了默认值或者可为空的情况下才为正确,其他情况均是错误的。当表定义中有默认值的时候,插入记录可以省略该字段的数据。9HAVING子句有什么作用?HAVING子句和WHERE语句一样都是实现查询功能中条件的控制和数据的选择,WHERE 子句不能包含聚集函数,而HAVING 子句一般包含聚集函数。HAVING 子句还可以用来对分组结果进行筛选。10当通配字符作为普通字符参与匹配查询时,如何解
10、决这样的问题? 通过在ESCAPE子句中指定转义符、在查询条件下使用转义符指定某个通配字符是正常字符;将通配符用方括号括起来,指定一个字符、字符串或范围,要求所匹配对象为它们中任意一个。11可否利用视图进行数据的插入、删除、修改? 对由多表连接成的视图修改数据时,不能同时影响一个以上的基表,也不能删除视图中的数据对视图上的某些列不能修改,这些列是:计算列,内置函数列和行集合函数列对具有NOT NULL 的列进行修改时可能会出错。通过视图修改或者插入数据时,必须保证未显示的具有NOT NULL 属性的列有值,可以是默认值,IDENTITY 等,否则不能像视图中插入数据行如果某些列因为规则或者约束
11、的限制不能接受从视图插入的数据时,则插入数据可能会失败12根据自己的体会,谈谈视图在数据库体系中的作用。视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。视图中看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。视图还保证了数据的安全性。通过视图用户只能查询和修改他们所能见到的数据。数据库中的其它数据则既看不见也取不到。数据库授权命令
12、可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。13视图是如何保存的?视图中的数据是否真的存储在文件中?视图是一个虚拟表,是以脚本的形式存在于数据库中,即其中数据仍然是原来表的数据。视图中的数据任然是表中的数据,并不真的存储在文件中。14SQL SERVER有几种身份验证模式?区别是什么?不同验证模式的登录账户有何区别?SQL Server2005提供了两种对数据库资源的访问进行身份验证的模式:Windows身份验证和混合模式身份验证。Windows身份验证。配置SQL Server2005使用Windows身份验证时,只有通过身份验证的Window
13、s用户可以访问SQL实例。对于每个需要访问SQL实例的Windows用户,必须为其添加一个Windows登录。且该登录帐户必须为计算机的用户方可以访问SQL Server。混合模式身份验证。再混合模式身份验证下,Windows用户和SQL用户都可以访问数据库实例。需要为非Windows用户提供访问权限时,比如说另一个客户操作系统的用户需要访问SQL Server时就使用混合模式身份验证。15Sa账户有何特点? Sa账户是SQL Server的特殊账户,sa账户拥有服务器和所有的数据库。即Sa账户拥有最高的管理权限,可以执行服务器范围内所有操作。它是以SQL Server身份验证的,所以必须设置
14、一个密码。同时,sa账户的属性不可以更改,密码可以修改。Sa登录时无法删除的。16共有几种服务器角色?最高权限的角色是什么?能够创建数据库的角色是哪个?共有8种固定服务器角色,分别是:sysadmin,serveradmin,setupadmin,securityadmin,processadmin,dbcreator,diskadmin,bulkadmin;同时每一个登录用户都属于public服务器角色。最高权限的角色是sysadmin;能够创建数据库的角色是:sysadmin,dbcreator;17数据库用户和登录账户有什么关系?guest是什么用户?有何作用?这是两种不同级别的安全机制
15、,登录账户是SQL Server级的安全性设置,而数据库用户则是数据库级的安全性设置。登录账户用于登录服务器,但是当某一用户要访问某个数据库时,除了可以成为服务器的一个登录以外,还必须成为这个数据库的用户账户,即获得一定的授权。数据库用户账号在一般情况下是从某个登录账户中映射过来的。Guest是来宾用户,是用来共享文件的。任何一个登录都可以以此身份访问数据库。Guest自动本身只具有public权限。也可以由其他用户授权。18数据库角色有哪两类?PUBLIC角色有何特点?数据库角色分为固定的数据库角色和用户定义数据库角色。每个数据库都有一系列固定数据库角色。虽然每个数据库中都存在名称相同的角色
16、,但各个角色的作用域只是在特定的数据库内。用户定义数据库角色是用户根据工作的职能定义一系列角色,并给每个角色指派了适合这项工作的权限。从而在数据库中管理这些权限。PUBLIC角色的特点:默认不具有任何权限,但用户可对此角色进行授权,他不能被删除,是所有user自动拥有的角色。数据库中的每个用户都属于 public 数据库角色。如果想让数据库中的每个用户都能有某个特定的权限,则将该权限指派给 public 角色。如果没有给用户专门授予对某个对象的权限,他们就使用指派给 public 角色的权限。19用户与架构有什么关系?系统默认架构是什么?怎样为用户指定架构?SQL Server 2000中数据
17、库用户和构架是隐式连在一起的,架构将用户和权限之间建立了一个间接地方式。数据库架构是一个独立于数据库用户的非重复命名空间,可以将架构视为对象的容器。每个数据库用户都是与该用户同名架构的所有者;而在SQL Server 2005中构架和用户是不同的实体。一个对象只能属于一个架构,就像一个文件只能存放于一个文件夹中一样。与文件夹不同的是,架构是不能嵌套的。系统默认架构是dbo架构;通过使用CREATE USER 和ALTER USER 语句,可以分配一个默认架构;也可以通过SSMS在该用户的属性下面分配一个默认架构。20. 什么是安全对象?怎样为数据库用户指定查询表的权限?安全对象是SQL Ser
18、ver 数据库引擎授权系统控制对其进行访问的资源。安全对象范围有服务器、端点和架构。为指定数据库用户授予table的权利,然后在下面的权限中选择select即可。 授权命令:GRANT ALL PRIVILEGES | permission ( column ,.n ) ,.n ON class : securable TO principal ,.n WITH GRANT OPTION AS principal 21 简述自定义函数、存储过程和触发器的异同。 自定义函数:接受参数、执行操作并且将运算结果以值的形式返回的例程。自定义函数有且只有一个返回值,就像普通的函数一样,可以直接在表达式中
19、嵌入调用。 存储过程:是一个可重用的代码模块,可以高效率地完成指定的操作。存储过程可以没有返回值,也可以有任意个输出参数,必须单独调用。 触发器:当表或视图中的某些重要数据发生变化 时,为了保持数据的一致性和完整性,可以自动执行某段程序保证相关联其他数据也跟着进行相应的变化。能完成这种功能的程序就是触发器,它是一种特殊类型的存储过程。触发器是一种特殊类型的存储过程,但是不能直接被调用执行,只能自动执行,在对特定表或列作特定类型的数据修改时执行。22 什么是游标?应用游标的步骤是什么? 游标是一种处理数据的方法,它可以对结果集进行逐行处理,也可以指向结果集中的任意位置,并对该位置的数据进行处理。
20、 应用游标的步骤:声明游标打开游标读取游标关闭游标释放游标。五、分析讨论首先第18个关于验证授权前后用户操作的差别那步我不会验证,在游标那题里面也没有用到事务,感觉自己在游标、自定义编程、存储过程等方面的基础及学习较为薄弱。刚开始将系统想得很大,后来在做的过程中发现一环套一环,如果做整个酒店管理系统真的很复杂,还包括财务管理、仓库管理、员工管理等方面,最后我和搭档商量决定只做客房及顾客信息管理等的内容,实现的功能也相对较少。相信经过一步一步的学习,我们的能力也会进一步的提升,努力作出比较完善的信息系统。 以下为本次实验的过程记录报告撰写。(可包括必要的截图)MC酒店前台管理系统一、 系统需求分
21、析1、 业务分析 工作人员登录:工作人员登录,并且有权限的限制,不同的权限允许的操作不同; 客房预订:客人可以提前预定房间,可以要求房间的类型,入住时间等; 取消预定:客人可以对已经预定的客房进行取消预定; 入住登记:对入住的客户的信息进行录入,客户入住房间; 退房登记:入住的客户离开,进行退房登记,更新客房客户信息; 客房信息查询:客户可以要求查询自己的房间号,剩余房间数量,房间信息等信息; 客户信息查询:客户可以要求查询自己的相关信息,酒店可以根据需要查询客户的信息;2、 功能需求分析 功能总流程图酒店前台管理系统登录窗口身份验证权限识别相关操作预定房间取消预定退房登记客房信息查询入住登记
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 实务 实验 报告 酒店 前台 管理 系统
链接地址:https://www.31ppt.com/p-2033086.html