付费下载
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据库原理及应用实验指导书实验一数据库的建立实验目的:掌握数据库的创建、基本表的创建和数据插入的方法实验要求:使用Oracle11g进行数据库的创建、基本表的创建和数据插入实验条件:计算机,Oracle11g实验内容:1、假设你是DBA需要定义系统中的所有表。试根据下面给出的关系模式,用SQL完成数据表的建立。假设“阿里巴巴”酒店数据库中有如下的几个关系模式:(1)客户个人信息(身份证号,姓名,性别,年龄,工作单位)(2)客户入住信息(身份证号,客房号,入住时间,退房时间)(3)客房(客房号,客房类型号)(4)定价(客房类型号,客房类型名,单价)(5)订票(身份证号,机票号,订票时间)(6)机
2、票(机票号,起始地,目的地,起飞时间,到达时间,机票价格,机票状态,航空公司号)注:机票状态只有三种0:未出票1 :已出票,但未被客户取走2 :已出票且已被客户取走(7)航空公司(航空公司号,航空公司名,电话)(8)雇员(雇员号,姓名,雇员年龄,雇佣日期,被投诉次数)(9)打扫(雇员号,客房号)说明:数据库表中各个字段的数据类型及宽度,请根据实际情况自定。数据库名、表名、字段名中英文均可,但需要有一定的实际含义。2、试根据下面的完整性约束要求,用SQLX寸上面已经建立好的“阿里巴巴”酒店数据库表进行完整性约束定义。(1)雇员的年龄必须大于20岁小于55岁,被投诉次数不能超过10次(2)客户的性
3、别只能是“男”或“女”。(3)客户每次入住的客房号和入住时间不能为空。(4)各种类型客房的定价不得低于100元,也不得高于2000元。(5)机票的状态只能有三种:0:未出票1 :已出票,但未被客户取走2 :已出票且已被客户取走实验二数据库的查询、更新实验目的:掌握数据库的查询、更新的方法实验要求:使用Oracle11g实现数据库的查询、更新操作实验条件:计算机,Oracle11g实验内容:1、试用SQLI成下面10个查询操作。(1)查询各客户的姓名和工作单位。(2)查询“张桦”客户的身份证号和年龄。(3)查询标准房的价格。(4)查询“李明”先生所住的客房号码及入住的时间。(5)查询“张桦”先生
4、所订客房的价格。(6)查询还有哪些机票已经出票但未被取走。(7)查询被投诉的雇员的姓名及次数。(8)查询各雇员姓名及所负责打扫的客房号。(9)查询“张庭”雇员负责打扫的客房的号码。(10)查询各航空公司的名称和电话。2、试用SQLI成下面6个查询操作。(1)查询空标准房的房间号。(2)查询身份证号为户最近入住酒店的日期是什么,住了几天。(3)查询空双人房的数目。(4)哪些机票已出票,但还未被取走,查询订购这些机票的房客姓名和客房号,以便及时通知他们来取票。(5)查询从未订过机票的客户的数目。(6)查询总共从东方航空公司(EASTERNAIRLINES订购
5、了多少张机票。3、试用SQLI成如下的更新操作(1)酒店新进了一名打扫客房的雇员,其雇员号为“E110,姓名是“张新”,雇佣日期为“7/20/2007”,试将该雇员的信息插入相应的表。(2)身份证号为“31022219661004001f,姓名是“张明”,年龄为35岁的男客户到酒店订了一间客房号为“1100”的客房,请对相应的表进行相应的操作。(3)身份证号为客户退房了,请对相应的表进行相应的操作。(4)将“E101”雇员的投诉次数加1。(5)酒店欲解雇被投诉次数大于5次的雇员,试对相应的表进行相应的操作。实验三视图、存储过程的使用实验目的:掌握数据库视
6、图、存储过程的创建、修改和删除的方法实验要求:使用Oracle11g实现数据库视图、存储过程的创建和使用实验条件:计算机,Oracle11g实验内容:该实验用学生借书数据库XSBOQK学生借书数据库相关信息如下:数据库名:XSBOOK数据文件名:XSBOOK日志文件名:XSBOOK_Log图书借阅系统的数据库为XSBOOK该数据库主要由学生(XS)、图书(BOOK、借阅(JY)3个表构成,依托3个基本表创建视图和存储过程。表1学生信息表(XS)表结构字段名类型与宽度是否主码是否允许空值说明借书证号CHAR(8)VX姓名VARCHAR2(8)xX专业VARCHAR2(20)xX性别CHAR(2)
7、xX借书量INTxX默认值为0表2学生信息表(XS)样本数据借书证号姓名专业名性别借书量10000001王娟计算机女410000002李宏计算机男310000003朱小波计算机男320000001李小丽英语女220000002吴涛英语男0表3图书信息表(BOOK结构字段名类型与宽度是否主码是否允许空值说明ISBNCHAR(16)VX书名VARCHAR2(30)xX作者VARCHAR2(8)xX出版社VARCHAR2(20)xX价格FLOATxX复本量INTxX当对书进行插入、删除时,复本量应等于库存量库存里INTXX表4图书信息表(BOOK样本数据ISBN书名作者出版社价格复本量库存里7-11
8、1-06359-7We惊占点安全刘宗田机械工业出版社17527-113-04908-7,(SP.NET程序设计陈惠贞机械工业出版社551097-115-07715-0;SP&WEB数据库王国荣人民邮电出版社59527-115-10162-0计算机网络教程谢希仁人民邮电出版社2812107-302-03035-9C语百程序设计谭浩强清华大学出版社481067-505-37908-9WE邦序设计吉根林电子工业出版社2587表5借阅表(JY)结构字段名类型与宽度是否主码是否允许空值说明借书证号CHAR(8)XX当借一本书时,BOOK勺库存量应ISBNCHAR(16)xX减1,同时,借书人的借书量应加
9、1;当还一本书时,BOOK勺库存量应加1,同时,借书人的借书量应减1索书号CHAR(10)VX借书时间DATExX表6借阅表(JY)样本数据借书证号ISBN索书号借书时间100000017-111-06359-711000000012011-03-01100000017-111-06359-711000000022011-05-10100000017-115-07715-031000000012011-05-10100000017-505-37908-961000000012011-09-01100000027-111-06359-711000000032011-03-10100000027-
10、113-04908-721000000012011-03-11100000027-302-03035-951000000012011-03-11100000037-302-03035-951000000022011-04-10100000037-302-03035-951000000032011-04-10100000037-115-10162-041000000012011-05-19200000017-115-10162-041000000022011-04-19200000017-302-03035-951000000042011-04-191、视图的创建和使用(1)把3个基本表联系起来
11、,方便需要3表关联的功能使用SQL命令如下:CREATEVIEWRBLASSELECTXSf书证号,JY.索书号,JY.ISBN,BOOK.书名,BOOK.出版社,BOOK价格,JY.借书时间FROMXSINNERJOINJYONXS.借书证号=JY.借书证号INNERJOINBOOKONBOOK.ISBN=JY.ISBN(2)功能测试SELECT*FROMRBL观察3表关联的字段数据正确性。2、存储过程的创建和使用?参数借书证号(in_ReaderID)、ISBN(in_ISBN)、图书ID(in_BookID)、执行信息(out_str)。?实现功能根据存储过程的前3个参数,实现读者图书“
12、借阅”。第4个参数为输出参数,将存储过程的执行情况以字符串形式赋予此参数。?编写思路(1)根据“借书证号”查询XS表是否存在该读者,如果不存在,则将输出参数out_str赋值为“该读者不存在”并返回0,存储过程结束,表示不能借书。(2)根据ISBN查询BOOW是否存在该图书,如果不存在,则将输出参数赋值为“该图书不存在”并返回0,存储过程结束,表示不能借书。(3)根据“借书证号”查询XS表中该读者的借书量。如果借书量=5,则将输出参数赋值为“读者借书量不能大于5”并返回0,存储过程结束,表示不能借书。(4)根据ISBN查询BOOKS中该图书的库存量。如果库存量=0,则将输出参数赋值为“图书库存
13、量为0”并返回0,存储过程结束,表示不能借书。(5)查询JY表中该读者是否已经借阅该图书,如果已经借过,则将输出参数赋值为“读者已经借过该书”并返回0,存储过程结束,表示不能借书。(6)查询JY表中该索书号是否已经存在,如果存在则将输出参数赋值为“该索书号已存在”并返回0,存储过程结束,表示不能添加借书记录。(7)使JY表增加一条该读者借书记录;XS表中该读者的借书量加1;BOOK中该图书(对应ISBN)记录的库存量减1。存储过程结束,将输出参数赋值为“借书成功”并返回1,表示借书成功。(8)如果存储过程执行过程中遇到错误,则回滚之前进行的操作,并将输出参数赋值为“执行过程中遇到错误”并返回0
14、,表示存储过程执行过程中遇到错误,回滚到执行存储过程前的状态。?实现方法PL/SQL如下:CREATEORREPLACEPROCEDUREBook_Borrow(in_ReaderIDinchar,in_ISBNinchar,in_BookIDinchar,out_stroutchar)ISCt_ReaderNumber(10);Ct_ISBNNumber(10);Ct_MaxReaderNumber(10);Ct_StoreNumber(10);Ct_HaveReadNumber(10);Ct_BookIDNumber(10);Error_NumerNumber(10);no_resultE
15、xception;BEGINError_Numer:=0;out_str:=;SELECTcount(*)intoCt_ReaderFROMXSWHERE借书证号=in_ReaderID;IFCt_Reader1THENBEGINout_str:=该读者不存在;Error_Numer:=1;END;ENDIF;SELECTcount(*)intoCt_ISBNFROMBOOKWHEREISBN=in_ISBN;IFCt_ISBN5THENBEGINout_str:=读者借书量不能大于5;Error_Numer:=1;END;ENDIF;SELECT库存量intoCt_StoreFROMBOOK
16、WHEREISBN=in_ISBN;IFCt_Store=0THENBEGINout_str:=图书库存量为0;Error_Numer:=1;END;ENDIF;SELECTcount(*)intoCt_HaveReadFROMJYWHERE借书证号=in_ReaderIDandISBN=in_ISBN;IFCt_HaveRead0THenBEGINout_str:=读者已经借过该书;Error_Numer:=1;END;ENDIF;SELECTcount(*)intoCt_BookIDFROMJYWHERE索书号=in_BookID;IFCt_BookID0THENBEGINout_str:
17、=索书号已存在;Error_Numer:=1;END;ENDIF;IFError_Numer=0THENINSERTINTOJYVALUES(in_ReaderID,in_ISBN,in_BookID,sysdate);UPDATEXSSET昔书量=借书量+1WHERE昔书证号=in_ReaderID;UPDATEBOOKSET库存量=库存量-1WHEREISBN=in_ISBN;out_str:=借书成功;IFSQL%NOTFOUNDTHENRAISEno_result;ENDIF;COMMIT;dbms_output.put_line(out_str);ELSEdbms_output.pu
18、t_line(out_str);ENDIF;EXCEPTIONWHENno_resultTHENDBMS_OUTPUT.PUT_LINE(执行过程中遇至胜昔误!);DBMS_OUTPUT.PUT_LINE(out_str);ROLLBACK;WHENOTHERSTHENDBMS_OUTPUT.PUT_LINE(SQLCODE|-|SQLERRM);END;?功能测试创建完存储过程Book_Borrow后可以使用PL/SQL语句验证图书借阅是否能够实现:SELECT(昔书证号,借书量FROMXSWHER借书证号=10000001;/*查询10000001读者的原借书量*/SELECTISBN,库存量FROMBOOKWHEREISBN=7-115-10162-0;/*查询图书的原库存
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026青海黄南州同仁市移动公司招聘备考题库及答案详解(历年真题)
- 2026北京一零一中教育集团矿大分校招聘备考题库附答案详解(满分必刷)
- 2026辽宁朝阳经济技术开发区消防救援大队招录政府专职消防队员10人备考题库含答案详解(达标题)
- 2026湖南第一师范学院诚聘88人备考题库及答案详解(各地真题)
- 2026年吉林大学辅导员招聘补充备考题库及答案详解(名校卷)
- 2026黑龙江哈尔滨市阿城区补充招聘公益性岗位劳动保障协理员80人备考题库附答案详解(基础题)
- 2026陕西延安老年大学招聘备考题库(含答案详解)
- 2026年福建省福州市鼓楼区阳光朵朵家庭服务有限公司公开招聘备考题库及答案详解(典优)
- 2026河南信阳光山县东岳实业有限公司招聘2人备考题库含答案详解(b卷)
- 2026广东佛山市高明发展投资建设集团有限公司招聘第三期工作人员2人备考题库及完整答案详解
- 2026苏教版六年级下册数学期中测试卷(附答题卡和答案)
- 福建厦门第二中学2025-2026学年高二第二学期4月阶段英语试题(含解析)
- 奋战30天誓圆高考梦+2026届高三下学期高考倒计时30天主题班会
- 重大网络安全攻防演练防守解决方案
- 2025年江西景德镇市八年级地生会考真题试卷(+答案)
- 2026年教师资格(心理健康教育学科知识与教学能力)考试题及答案
- 2026年天津市和平区中考一模数学试卷和答案
- 骨科骨折固定技术培训指南
- 河北农业农村厅所属事业单位笔试试题2024版
- 2026年北京市中考数学模拟试卷
- 小区安全生产制度汇编
评论
0/150
提交评论