版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
《数据库原理》实验指导书实验1熟悉SQLServer一、实验目的熟悉数据库表的创建及管理方法。熟悉SQLServer的运行环境。二、实验内容1.使用企业管理器创建数据库。使用企业管理器创建基本表。三、实验过程1.首先通过【开始】一【程序】一【MicrosoftSQLServers]一【企业管理器】,打开企业管理器界面,如图1。-1口同SQLServerEnterpriseMana苦迁-[控制台根目录-1口同雀]控制台(£)窗口地)帮助QI)操作(A)操作(A)查看(Y)工具(I)_i控制台根目录白••副_i控制台根目录白••副MicrosoftSQLServers
白句SQLServer组白••奥-」数据库GUOLH(WindowsBT)亩…E-S-亩,E-S-囹|mastermodelImsdbNorthwind9pubsytempdbGUOLH(WindowsNT)6个项目数蛔库数蛔转换服务管理复制安全性支持服务_MetaDataServi>:es+」数据转换服务+」管理+」复制+」安全性+」支持服务企业管理器2.在“数据库”上按鼠标右键选择“新建数据库”,出现数据库属性窗口,+」数据转换服务+」管理+」复制+」安全性+」支持服务企业管理器2.在“数据库”上按鼠标右键选择“新建数据库”,出现数据库属性窗口,在常规选项页的名称栏中输入数据库名称StuCourse。3.利用“企业管理器”在数据库StuCourse中建立三个表Student、Course>SC,结构如下:表1学生信息表:student列名数据类型长度完整性约束snochar8主键snamechar4不为空
ssexchar1sageintsdeptchar10表2课程信息表:course列名数据类型长度完整性约束cnochar2主键cnamechar30ccreditint表3学生选课表:sc列名数据类型长度完整性约束snochar8主属性,外键cnochar2主属性,外键gradeint是点击StuCourse数据库下“表”对象,右键选择“新建密。在表设计器(如图2)中输入学生表的各列及其数据类型,完毕后保存为“Student”表。图2表设计器以同样的方法创建其余表。4.建立主码(1)给学生表student建立主码。在student表上单击右键选择“设计表”,选中Sno,点击右键,选择设置主键。选定的关系底):FIC_Ei:_EtiiderLt关系名(Kj:FIC_sc_5tiidHrLt/对复制强制关系⑥图4设置外码环对IHSERT和UPDATE强制卖系。⑶点击“新建”按钮!,并在其中选择主键表“student选定的关系底):FIC_Ei:_EtiiderLt关系名(Kj:FIC_sc_5tiidHrLt/对复制强制关系⑥图4设置外码环对IHSERT和UPDATE强制卖系。⑶点击“新建”按钮!,并在其中选择主键表“student”外键表“
后模闭相关啜可创建好外码。都选择“sno,。然后(4)采用同样的方法给sc表设定外码cno。6.设定自定义完整性关闭c”,属性⑵打开student表,则发现向其中输入数据时,在Sno列不能输入相同的数据,也不能取空值。(3)用同样的方法设置其他表的主码.5.设定外码⑴给sc表设定外码sno。打开student表的设计器,点击右键,选择“关系”。⑵选择“关系”后会弹出“属性”对话框,如图4.关系 索引/麋CHECK约束EtudeiLt表名:
EtudeiLt打开“student”表设计器,点击右键,选择'CHECK约束”,在弹出的窗口中,点击“新建”按钮,并在“约束表达式”文本框中输入条件“age>15andage<25”如图5所示,然后点击关闭。性性age>15:hldage<50际创建中检查现存数据®17对复制强制约束[7对INSERT和UPDATE强制约束堡)图5自定义完整性以同样的方式再在“student”上创建一个约束,约束条件是sse女’。女’。关闭帮助7.输入数据用鼠标右键单击student表,在弹出菜单中选择:“打开表”,“返回所有行”,然后在表格中输入相应的记录。Student表noSsnamesex8Sagedept0丽王女匚 20C0李红女匚 18C0亮王男号 17MCourse表CnoCnameccredit1英语42数学43语文24物理1Sc表SnoCnoGrade01165013750219003288034608.下面来验证前面设置的外码、自定义完整性:(1)在sc表中分别添加记录“04295”和“02670”.看一下能否添加到表中?为什么?“04295”的Sno属性的值“04”在表Student中找不到一个元组,其Sno属性的值与之相等。“02670”的Cno属性的值“6”在表Course中找不到一个元组,其Cno属性的值与之相等。因此以上2条记录不能被添加。(2)在student表中分别尝试添加以下记录“04孙卫男35CS”和“04孙卫重20CS”。考虑不能添加的原因是什么?记录“04孙卫男35CS”不满足约束条件“age>15andage<25”记录“04孙卫重20CS”不满足约束条件“ssex=’男’orssex=’女’”。实验2SQL定义语句一、实验目的熟悉SQL语言环境熟练使用SQL语言所提供的定义功能二、 实验内容练习creat语句的使用练习drop语句的使用3.练习alter语句的使用三、 实验过程1.利用create语句创建一个student表,它由学号Sno、姓名Sname、性别Ssex、年龄Sage、系别Sdept五个属性组成。其中,学号是主码,姓名取值唯一。CREATETABLEStudent(SnoCHAR(9)PRIMARYKEY/*列级完整性约束条件*/SnameCHAR(20)UNIQUE, /*Sname取唯一值*/SsexCHAR(2),SageSMALLINT,SdeptCHAR(20));将创建具有如下图1所示的表结构的数据库表。图1表结构2.建立一个"课程”表Courseo包含Cno、Cname、Cpno、Ccredit四个属性。其中Cno是主码,Cpno是外码,参照Cno属性。CREATETABLECourse(CnoCHAR(4)PRIMARYKEYCnameCHAR(40),Cpno CHAR(4),CcreditSMALLINT,FOREIGNKEY(Cpno)REFERENCESCourse(Cno));建立一个“学生选课”表SC。主码由Sno,Cno组成。Sno是外码,被参照表是Student,Cno是外码,被参照表是CourseoCREATETABLESC(SnoCHAR⑼,CnoCHAR(4),GradeSMALLINT,PRIMARYKEY(Sno,Cno),FOREIGNKEY(Sno)REFERENCESStudent(Sno),FOREIGNKEY(Cno)REFERENCESCourse(Cno));利用alter语句向student表增加入学时间SCOME列,其数据类型为日期型。AltertablestudentaddSCOMEDATE;图2修改后的表结构将年龄的数据类型由字符型改为整数。ALTERTABLEStudentALTERCOLUMNSageINT增加课程名称必须取唯一值的约束条件。ALTERTABLECourseADDUNIQUE(Cname);利用create命令在表student上按学号升序建立唯一索引。Createuniqueindexstusnoonstudent(SNO);注意:在创建了索引后需先打开才能生效。Course表按课程号降序建唯一索引。CREATEUNIQUEINDEXCoucnoONCourse(CnoDESC);利用drop命令删除在student表的按学号升序的唯一索引。Dropindexstusno;因为索引是依附于基本表的,基本表的修改将直接影响到索引,故没提供修改索引的命令。利用drop命令删除基本表CourseoDroptableCourse注意;基本表定义一旦删除,表中的数据、在此表上创建的索引和试图都将自动删除,故应慎重。一、 实验目的掌握用select语句实现简单的查询掌握用select语句实现带有各种查询条件的查询二、 实验内容用select语句实现单表查询用select语句实现连接查询用select语句实现嵌套查询用select语句实现集合查询三、 实验过程假设数据库中已存在三个基本表学生信息表student、课程表course和学生选课表sc。其中:学生信息表:student(SNO,SNAME,SSEX,SAGE,SDEPT)课程表:course(CNO,CNAME,CPNO,CCREDIT)学生选课表:sc(SNO,CNO,GRADE)查询所有年龄在20岁以下的学生的姓名及年龄。SelectSNAME,SAGEFROMSTUDENTWHERESAGE<20;查询名字中第2个为“立”的学生的姓名和学号。Selectsname,snoFromstudentWheresnamelike’_立%’;查询缺少成绩(成绩为空值)的学生的学号和相应的课程号。Selectsno,cnoFromcourseWheregradeISNULL;查询选修了3号课程的学生的学号及其成绩,查询结果按成绩降序排序。Selectsno,gradeFromscWherecno=’3’Orderbygradedesc;查询选修1号课程的学生的最高分数。SelectMAX(grade)FromscWherecno=’T;查询选修了3门以上课程的学生的学号。SelectsnoFromscGroupbysnoHavingCOUNT(*)>3;查询每个学生及其选课情况。Selectstudent.*,sc.*Fromstudent,scWherestudent.sno=sc.sno;查询选修2号课程且成绩在85分以上的所有学生。Selectstudent.sno,snameFromstudent,scWherestudent.sno=sc.snoandSo=’2’andSc.Grade>85查询其他系中比信息系所有学生年龄都小的学生姓名及年龄。Selectsname,sageFormstudentWheresage<all(selectsagefromstudentwheresdept=’IS’)andsdept<>’IS’;查询所有选修了1号课程的学生姓名。SelectsnameFromstudentWhereexists(select*fromscwheresno=student.snoandcno=T);查询选修了课程1或课程2的学生。SelectsnoFromscWherecno=’1’UnionSelectsnoFromscWherecno=’2’;本题也可用多重条件查询实现,主要是练习集合查询。建立数学系学生的视图,并要求进行修改和插入操作时仍需保证该视图中只有数学系的学生。Createviewm_studentAsSelectsno,sname,sageFromstudentWheresdept=’MA’Withcheckoption;建立信息系选修了1号课程的学生的视图。CreateviewIS_S1(sno,sname,grade)AsSelect*Fromstudent,scWheresdept=’IS’andStudent.sno=sc.snoandSo=T;14.删除m_student视图。Dropviewm_student;因为视图跟索引一样也依附于基本表,多基本表的修改同样可影射到视图,故也没提供修改视图的语句。在建立了视图后可象查询基本表一样对视图进行各种查询,但要求能进行转换,然后在执行修正了的查询。实验4SQL更新语句一、 实验目的掌握SQL更新语句的使用掌握SQL控制功能的实现二、 实验内容.练习update语句的使用.练习delete语句的使用.练习insert语句的使用.练习grant语句的使用.练习revoke语句的使用实验过程1.将一个新学生元组(学号:200215128;姓名:陈冬;性别:男;所在系:IS;年龄:18岁)插入到Student表中。insertintostudent(sno,sname,ssex,sdept,sage)values('200215128','陈冬','男','IS',18);2将学生张成民的信息插入到Student表中。insertintostudentvalues(‘200215126’,‘张成民’,‘男’,18,'cs');插入一条选课记录('200215128','1')。INSERTINTOSC(Sno,Cno)VALUES(‘200215128’,‘1’);对每一个系,求学生的平均年龄,并把结果存入数据库。第一步:建表CREATETABLEDept_age/*系名/*系名*//*学生平均年龄*/Avg_ageSMALLINT);第二步:插入数据INSERTINTODept_age(Sdept,Avg_age)SELECTSdept,AVG(Sage)FROMStudentGROUPBYSdept;将学生200215122选修2号课程改为选修1号课程。UpdatescSetcno=TWheresno=’200215122’andCno=’
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中西科工作制度
- 六无村工作制度
- 保全工作制度
- 一查工作制度
- 全友工作制度
- 医疗营销推广方案
- 安全骑行带头盔
- 清扫保洁安全培训
- 创业融资商业计划书-蓝色-科技风
- 台湾省工作制度
- 盘点:2026年AI智能CRM系统主流品牌
- 2026年发展对象党章测试题及答案
- 2026年宁夏葡萄酒与防沙治沙职业技术学院单招职业技能测试题库及答案详解(夺冠)
- 2026年阜阳职业技术学院单招职业技能测试题库附参考答案详解(能力提升)
- 装配式工程质量标准化管理手册
- DB42-T 2509-2026 数字乡村 地质资源信息化建设与应用规范
- 财税销售技巧培训课件
- GB/T 46894-2025车辆集成电路电磁兼容试验通用规范
- T∕CNCA 127-2025 煤炭建设工程造价参考指标
- 2026春统编版二年级下册道德与法治第四单元教学设计
- 粉末冶金培训课件
评论
0/150
提交评论