




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
UyearUyearUnameUplaceUnoUplaceUnoBelongSdnameSdorSclnoSnoSnameSageLiveDeptMajorClassStudentSunion BelongSdnameSdorSclnoSnoSnameSageLiveDeptMajorClassStudentSunionJJoinyearSjoin mSjoin n pCnumCnum qClyear 1ClyearCClmjnameBelongOpenClnoBelongOpenClnoMnameMnameCldname 1 1DnoBelong nDnoBelongDnameDorplaceDnameDorplaceDormitoryDwkplace 1 1DormitoryDwkplaceDnumDnum消除冲突和冗余后的E-R图UyearUyearUplaceUUnameUnoUnoSunionSunionJoinyearJoinyearSjoin mSjoinDorplaceDormitoryDnumDnameDwkplaceDnoBelongMjnamelyearClnumClnoOpenBelongSnoSnameSageLiveDeptMajortudentDorplaceDormitoryDnumDnameDwkplaceDnoBelongMjnamelyearClnumClnoOpenBelongSnoSnameSageLiveDeptMajortudentnp1ClassClass11n1 1 1三.逻辑结构设计stuunion(uno,uname,uyear,uplace)student(sno,sname,sage,clno)sjoin(uno,sno,joinyear)class(clno,clyear,cltotal)major(mjname,clno,dnl)dept(dno,dname,dwkplace,dtotal)dormitory(dno,dorplace)经检验,以上7个关系模式均满足第三范式要求四.应用程序中遇到的问题及解决方法根据设计好的关系模式,即可在SQLSever2008环境下编程。前面创建表、视图、触发器的过程都比较简单,创建存储过程的时候遇到了一点问题,班号更改以后无法把相关表中的班号也修改了,最后发现原因是student和major两个从表无法级联更新,于是又给这两个表增添了随着class表级联更新的属性,问题迎刃而解。最后创建游标的过程有点复杂,不过整体还是比较顺利的。五.总结这次上机实验收获还是挺多的,上课的时候学到了理论,当真正把理论运用到实践中的时候发现其实没那么容易。虽然只是设计了一个学生管理系统,这个系统规模不大,数据也不多,但是当真正设计这个数据库的时候过程是比较曲折的。我觉得重点就是根据需求设计E-R图,设计出E-R图后还要消除冲突和冗余,然后将E-R图转换为关系模式,还要对关系模式规范化,达到一个非常好的效果。此次上机实验也锻炼了同学之间的合作能力,我积极和同学探讨问题,也向老师请教问题,学到了好多课本上没有学到的知识。附录:代码:--student表createtablestudent(snovarchar(8)primarykey,snamevarchar(20)notnullunique,sageint,clnochar(6)referencesclass(clno));--class表createtableclass(clnochar(6)primarykey,clyearint,cltotalint)--major表createtablemajor(mjnamevarchar(20)primarykey,clnochar(6)referencesclass(clno),dnochar(2)referencesdept(dno))--dept表createtabledept(dnochar(2)primarykey,dnamevarchar(20)notnullunique,dworkplacevarchar(20),dtotalint)--dormitory表createtabledormitory(dorplacevarchar(20),dnochar(2)referencesdept(dno))--stuunion表createtablestuunion(unochar(6)primarykey,unamevarchar(20)notnullunique,uyearint,uplacevarchar(20))--sjoin表createtablesjoin(unochar(6)referencesstuunion(uno),snovarchar(8)referencesstudent(sno),joinyearint,primarykey(uno,sno))--创建视图createviewuname_utotal(uname,utotal)asselectuname,count(*)fromstuunion,sjoinwherestuunion.uno=sjoin.unogroupbystuunion.unamewithcheckoption;--创建触发器createtriggerinsert_cltotal_dtotalonstudentforinsertasdeclare@achar(6);declare@cchar(2);set@a=(selectclass.clnofromclass,insertedwhereclass.clno=inserted.clno);updateclasssetcltotal=cltotal+1whereclno=@a;set@c=(selectdept.dnofrommajor,dept,insertedwheremajor.dno=dept.dnoandmajor.clno=inserted.clno);updatedeptsetdtotal=dtotal+1wheredno=@c;createtriggerdelete_cltotal_dtotalonstudentfordeleteasdeclare@achar(6)declare@cchar(2)set@a=(selectclass.clno;fromclass,deleted;whereclass.clno=deleted.clno);updateclasssetcltotal=cltotal-1whereclno=@a;set@c=(selectdept.dnofrommajor,dept,deletedwheremajor.dno=dept.dnoandmajor.clno=deleted.clno);updatedeptsetdtotal=dtotal-1wheredno=@c;--创建存储过程createprocedurepro_modifycno@oldcnochar(6),@newcnochar(6),@classtotalintoutputasupdateclasssetclno=@newcnowhereclno=@oldcno;updatestudentsetclno=@newcnowhereclno=@oldcno;updatemajorsetclno=@newcnowhereclno=@oldcno;set@classtotal=(selectcltotalfromclasswhereclno=@newcno)declare@xintexecpro_modifycno@oldcno='011221',@newcno='051221',@classtotal=@xoutputprint@xaltertablestudentaddconstraintc1foreignkey(clno)referencesclass(clno)onupdatecascadealtertablemajoraddconstraintc2foreignkey(clno)referencesclass(clno)onupdatecascade--建立游标declare@Depvarchar(10);declare@Classvarchar(10);droptableChangecreatetableChange( dnochar(10)primarykey, dtotalint);insertintoChange(dno,dtotal)selectdept.dno,dept.dtotalfromdeptdeclareStuNumCheckcursorfor selectdno,clno frommajoropenStuNumCheckupdatedeptsetdtotal=0fetchnextfromStuNumCheckinto@Dep,@Classwhile@@FETCH_STATUS=0beginupdatedeptsetdtotal=dtotal+( selectCOUNT(*) fromstudent whereclno=@C
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 新质生产力催生新产业形态
- 宠物店服务质量管理方案
- 测绘地理信息行业新质生产力
- 2025年病理科镜下病理切片鉴定能力评估试卷答案及解析
- 民族学田野调查课件
- 2025年心血管内科心电图诊断与分析试题答案及解析
- 2025年肺功能科呼吸道疾病患者的肺功能检查要点模拟考试卷答案及解析
- 民族团结爱我中华课件
- 新质生产力与现代产业
- 新质生产力的核心解读维度
- 色素痣诊疗专家共识(2025版)解读
- 新能源空气能热泵项目节能评估报告(节能专用)
- 防腐考试题库及答案
- 转让民宿协议书范本
- 直营店管理制度
- 2025年第34届全国中学生物理竞赛预赛试卷及答案(完整版)
- 2025年特种设备作业人员客运索道修理S1证考试题库
- 【杭州智篆文化传播】2025天猫健身行业趋势白皮书
- 信访工作法治化培训讲座
- 《动物实验技术》课件-任务1:小鼠脓毒症模型建立
- SANAKOLAB100语言实验室建设方案
评论
0/150
提交评论