欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOCX文档下载  

    MYSQL练习题及答案.docx

    • 资源ID:14179574       资源大小:70.55KB        全文页数:8页
    • 资源格式: DOCX        下载积分:4
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要4
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    MYSQL练习题及答案.docx

    题目一问题描述:为治理岗位业务培训信息,建立3个表:S (S#,SN,SD,SA) S#,SN,SD,SA分别代表学号、学员姓名、所属单位、学员年龄C (C#,CN ) C#,CN分别代表课程编号、课程名称SC ( S#,C#,G ) S#,C#,G分别代表学号、所选修的课程编号、学习成绩1 .使用标准SQL嵌套语句查询选修课程名称为税收根底的学员学号和姓名-实现代码:SELECT SN,S# FROM SWHERE S# IN(SELECT S# FROM C,SCWHERE C.C#=SC.C#AND CN=N'税收根底')2 .使用标准SQL嵌套语句查询选修课程编号为C2'的学员姓名和所属单位-实现代码:SELECT S.SN,S.SD FROM S,SCWHERE S.S#=SC.S#AND SC.C#='C2'3.使用标准SQL嵌套语句查询不选修课程编号为C5'的学员姓名和所属单位-实现代码:SELECT SN,SD FROM SWHERE S# NOT IN(SELECT S# FROM SCWHERE C#='C5')4.使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位-实现代码:SELECT SN,SD FROM SWHERE S# IN(SELECT S# FROM SCRIGHT JOINC ON SC.C#=C.C# GROUP BY S#HAVING COUNT(*)=COUNT(S#)5 .查询选修了课程的学员人数-实现代码:SELECT学员人数=COUNT(DISTINCT S#) FROM SC6 .查询选修课程超过 5门的学员学号和所属单位-实现代码:SELECT SN,SD FROM SWHERE S# IN(SELECT S# FROM SCGROUP BY S#HAVING COUNT(DISTINCT C#)>5)题目二问题描述:此题用到下面三个关系表:CARD 借书卡.CNO卡号,NAME姓名,CLASS班级BOOKS 图书. BNO 书号,BNAME 书名,AUTHOR 作者,PRICE 单价,QUANTITY 库存 册数BORROW 借书记录. CNO借书卡号,BNO书号,RDATE还书日期 备注:限定每人每种书只能借一本;库存册数随借书、还书而改变.要求实现如下15个处理:1 .写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束.2 .找出借书超过5本的读者,输出借书卡号及所借图书册数.3 .查询借阅了 '"水浒'"一书的读者,输出姓名及班级.4 .查询过期未还图书,输出借阅者(卡号)、书号及还书日期.5 .查询书名包括 '"网络'"关键词的图书,输出书号、书名、作者.6 .查询现有图书中价格最高的图书,输出书名及作者.7 .查询当前借了 '"计算方法 '"但没有借 '计算方法习题集 的读者,输出其借书卡号,并 按卡号降序排序输出.8 .将'"C01"班同学所借图书的还期都延长一周.9 .从BOOKS表中删除当前无人借阅的图书记录.10 .如果经常按书名查询图书信息,请建立适宜的索引.11 .在BORROW表上建立一个触发器, 完成如下功能:如果读者借阅的书名是"数据库技 术及应用",就将该读者的借阅记录保存在 BORROW_SAVE表中(注ORROW_SAVE表结构 同 BORROW 表).12 .建立一个视图,显示 "力01"班学生的借书信息(只要求显示姓名和书名).13 .查询当前同时借有 '"计算方法 '"和'"组合数学"两本书的读者,输出其借书卡号,并按 卡号升序排序输出.14 .假定在建BOOKS表时没有定义主码,写出为 BOOKS表追加定义主码的语句.15 .对CARD表做如下修改:a.将NAME最大列宽增加到10个字符(假定原为 6个字符).b.为该表增加1列NAME (系名),可变长,最大 20个字符.1.写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束-实现代码:CREATE TABLE BORROW(CNO int FOREIGN KEY REFERENCES CARD(CNO),BNO int FOREIGN KEY REFERENCES BOOKS(BNO), RDATE datetime,PRIMARY KEY(CNO,BNO)2 .找出借书超过5本的读者,输出借书卡号及所借图书册数-实现代码:SELECT CNO 借图书册数=COUNT(*) FROM BORROWGROUP BY CNOHAVING COUNT(*)>53 .查询借阅了 '"水浒'"一书的读者,输出姓名及班级-实现代码:SELECT * FROM CARD cWHERE EXISTS(SELECT * FROM BORROW a,BOOKS bWHERE a.BNO=b.BNOAND b.BNAME=N'水浒 'AND a.CNO=c.CNO)4 .查询过期未还图书,输出借阅者(卡号) 、书号及还书日期-实现代码:SELECT * FROM BORROWWHERE RDATE<GETDATE()5 .查询书名包括 '网络'关键词的图书,输出书号、书名、作者-实现代码:SELECT BNO,BNAME,AUTHOR FROM BOOKSWHERE BNAME LIKE N'%网络 %'6 .查询现有图书中价格最高的图书,输出书名及作者-实现代码:SELECT BNO,BNAME,AUTHOR FROM BOOKSWHERE PRICE=(SELECT MAX(PRICE) FROM BOOKS)7 .查询当前借了 '"计算方法 '"但没有借"计算方法习题集 的读者,输出其借书卡号,并按 卡号降序排序输出-实现代码:SELECT a.CNOFROM BORROW a,BOOKS bWHERE a.BNO=b.BNO AND b.BNAME=N' 计算方法 'AND NOT EXISTS(SELECT * FROM BORROW aa,BOOKS bbWHERE aa.BNO=bb.BNOAND bb.BNAME=N' 计算方法习题集'AND aa.CNO=a.CNO)ORDER BY a.CNO DESC8 .将'"C01"班同学所借图书的还期都延长一周-实现代码:UPDATE b SET RDATE=DATEADD(Day,7,b.RDATE)FROM CARD a,BORROW bWHERE a.CNO=b.CNOAND a.CLASS=N'C01'9 .从BOOKS表中删除当前无人借阅的图书记录-实现代码:DELETE A FROM BOOKS aWHERE NOT EXISTS(SELECT * FROM BORROWWHERE BNO=a.BNO)10 .如果经常按书名查询图书信息,请建立适宜的索引-实现代码:CREATE CLUSTERED INDEX IDX_BOOKS_BNAME ON BOOKS(BNAME)11 .在BORROW表上建立一个触发器,完成如下功能:如果读者借阅的书名是"数据库技术及应用",就将该读者的借阅记录保存在BORROW_SAVE表中(注ORROW_SAVE表结构同 BORROW 表) -实现代码:CREATE TRIGGER TR_SAVE ON BORROWFOR INSERT,UPDATEASIF ROWCOUNT>0INSERT BORROW_SAVE SELECT i.*FROM INSERTED i,BOOKS bWHERE i.BNO=b.BNOAND b.BNAME=N'数据库技术及应用'12 .建立一个视图,显示 "力01"班学生的借书信息(只要求显示姓名和书名)-实现代码:CREATE VIEW V_VIEWASSELECT a.NAME,b.BNAMEFROM BORROW ab,CARD a,BOOKS bWHERE ab.CNO=a.CNOAND ab.BNO=b.BNOAND a.CLASS=N'力 01'13.查询当前同时借有"计算方法 '"和'"组合数学 '两本书的读者,输出其借书卡号,并按卡 号升序排序输出-实现代码:SELECT a.CNOFROM BORROW a,BOOKS bWHERE a.BNO=b.BNOAND b.BNAME IN(N'计算方法 ',N'组合数学 ')GROUP BY a.CNOHAVING COUNT(*)=2 ORDER BY a.CNO DESC14.假定在建BOOKS表时没有定义主码,写出为BOOKS表追加定义主码的语句-实现代码:ALTER TABLE BOOKS ADD PRIMARY KEY(BNO)15.1 将NAME最大列宽增加到10个字符(假定原为 6个字符)-实现代码:ALTER TABLE CARD ALTER COLUMN NAME varchar(10)15.2为该表增加1列NAME (系名),可变长,最大 20个字符-实现代码:ALTER TABLE CARD ADD 系名 varchar(20)题目三假设有下面两个关系模式:职工(职工号、姓名、年龄、职务、工资、部门号),其中职工号为主码;部门(部门号、名称、部门经理、 ) ,其中部门号为主码;用SQL语言定义这两个关系模式,要求在模式中完成以下完整性约束条件的定义:定义每个模式的主码和非空约束;定义参照完整性;定义职工年龄不得超过60岁.答:Create table bm(bmno char (10) primary key ,Bmname char (20) not null ,Bmjl char (10) not null ,Bmtel char (10) unique);Create table zhigong(zgno char (10),Zgname char (20),Zgage int ,Zgsal numeric(10),Bmno char(10),Primary key(zgno),Foreign key(bmno) reference bm(bmno)On delete no actionOn update cascade,Constraint zg1 check(zgage<=60);题目四1、有以下三个关系模式:学生关系S,包括学号SNo、姓名SN、年龄SA、系别SD;课程关系C,包括课程号 CNo、课程名CN、学分CC;学生选课关系 SC,包括SNo、CNo和成绩Go(1)用SQL语言定义SC表,注意:说明主键码和外键码(如果有的话).(2)对于学生选课关系 SC,授予李小兰删除权限以及对SNo和CNo的修改权限.(3)删除学号为“的学生.(4)从学生选课关系 SC中,删除王云(学生关系中可能有重名)的所有选课.答:(1) CREATE TABLE SC SNo INT,CNo INT,G INT,PRIMARY KEY( SNo, CNo),FOREIGN KEY(SNo) REFERENCES S( SNo),FOREIGN KEY(CNo) REFERENCES C(CNo);(3 分) GRANT DELETE, UPDATE( SNo, CNo) ON SC TO 李小兰;(3 分)(3) DELETE FROM S WHERE Sno = 9900205;(3 分)(4) DELETE FROM SCWHERE SNo IN( SELECT SNoFROM SWHERE SN ='王云);题目五设某商业集团关于商店销售商品的数据库中有三个根本表:商店 SHOP (S#, SNAME, AREA, MGR_NAME)其属性是商店编号,商店名称,区域名,经理姓名.销售 SALE (S#, G#, QUANTITY)其属性是商店编号,商品编号,销售数量.商品 GOODS (G#, GNAME, PRICE其属性是商品编号,商品名称,单价.(1)写出以下查询的关系代数表达式:检索销售“冰箱的商店的编号和商店名称.(2)从SALE表中,把“开开商店中销售单价高于1000元的商品的销售元组全部删除.(3)写出以下操作的SQL语句:统计区域名为“ EAST'的所有商店销售的每一种商品的总数 量和总价值. 关系代数表达式:兀 S#, SNAME (yGNAME='冰箱'(SHOP?SALE?GOODS)( 3 分) DELETE FROM SALEWHERE S# IN (SELECT S#FROM SHOPWHERE SNAME='开开商店)AND G# IN ( SELECT G#FROM GOODSWHERE PRICE>1000);(3) SELECT C.G#, GNAME , SUM (QUANTITY) AS SUM_QUANTITY, PRICE*SUM (QUANTITY) AS SUM_VALUEFROM SHOP A, SALE B, GOODS CWHERE A.S#=B.S# AND B.G#=C.G# AND AREA='EAST'GROUP BY C.G#, GNAME;题目六:某学校有假设干系,每个系有假设干学生,假设干课程,每个学生选修假设干课程, 每门课有假设干学生选修,某一门课可以为不同的系开设, 今要建立该校学生选修课程的数据库, 数据库中要 存放以下信息:系:系名,系代号,系主任名, 学生:学号,姓名,年龄,性别,所在系代号课程:课程号,课程名称每个学生选修某门课的日期,成绩每个系开设的课程.请你设计:关于此学校数据库的 E-R图并把此E-R图转换为关系模型.指出各关系的主码.答:日期学生学号姓名,年龄,性别,系代码系系代码,系名,系主任名, 课程课程号,课程名称学生选课学号 课程号 选课日期 成绩系-课程系代码,课程号指出各关系的主码.学号/系代码/课程号/学号,课程号/系代码,课程号题目七假设某商业集团数据库中有一关系模式R如下:R 商店编号,商品编号,数量,部门编号,负责人如果规定:每个商店的每种商品只在一个部门销售;每个商店的每个部门只有一个负责人;每个商店的每种商品只有一个库存数量.试答复以下问题:1根据上述规定,写出关系模式R的根本函数依赖.2找出关系模式R的候选码.3试问关系模式R最高已经到达第几范式为什么4如果R不属于3NF,请将R分解成3NF模式集.答:1有三个函数依赖:商店编号,商品编号一部门编号商店编号,部门编号一负责人商店编号,商品编号一数量2 R的候选码是商店编号,商品编号3由于R中存在着非主属性“负责人对候选码商店编号、商品编号的传递函数依赖,所 以R属于2NF, R不属于3NF.4将R分解成:R1 商店编号,商品编号,数量,部门编号 R2 商店编号,部门编号,负责人 题目八假设某商业集团数据库中有三个实体集.“仓库实体集,属性有仓库号、仓库名和地址等;“商店实体集,属性有商店号、商店名、地址等;“商品实体集,属性有商品号、商品名、单价.设仓库与商品之间存在“库存联系,每个仓库可存储假设干种商品,每种商品存储在假设干仓库中,每种商品可在假设干商店里销售,每个商店销售一种商品有月份和月销售量两个属性;仓库、商店、商品之间存在着“供给联系,有月份和月供给量两个属性.1试画出ER图.2将ER图转换成关系模型.3说明主键和外键.答1.2 .仓库仓库号,仓库名,地址商品商品号,商品名,单价商店商店号,商店名,地址库存仓库号,商品号,日期,库存量销售商店号,商品号,月份,月销售量供给仓库号,商店号,商品号,月份,月供给量3 .仓库号/商品号/商店号/仓库号,商品号 /商店号,商品号 /仓库号,商店号,商品号

    注意事项

    本文(MYSQL练习题及答案.docx)为本站会员(scccc)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开