资源描述
实验 4 数据查询一、实验目的1. 掌握使用 Transact-SQL 的 SELECT 语句进行基本查询的方法。2. 掌握使用 SELECT 语句进行条件查询的方法。3. 掌握SELECT语句的GROUP BY和ORDER BY子句的作用和使用方法。4. 掌握嵌套查询的方法。5. 掌握连接查询的操作方法。二、实验内容和步骤1在 studentsdb 数据库中,使用下列 SQL 语句将输出什么?并说明语句中 使用函数所实现的功能。(1) SELECT COUNT(*) FROM 成绩表SELECT COUNT (*) FROH 成绩表.西列色L1 I 15功能:统计成绩表的行数(2) SELECT SUBSTRING(姓名,1,2) FROM 学生表氏列名J_茹卫j2张为3马东4贱达5东方6郭文7肖海0 张明功能:显示指定查询的前两个字段号。(3) SELECT UPPER(kelly)SELECT UPPER(1 kellyl1 )1ikELLY“功能:将小写的字符转换成大写的字符。(4) SEIECT Replicate(kelly,3)|氏列名SELECT Replicate (kelly,31販匚麻鼻功能:重复 3 次字符串。(5) SELECT SQRT(分数)FROM 成绩表 WHERE 分数=85SELECT SQRT(分数)FROM 成绩表WHERE 井数 =85|氏列名19.48603290050514 |29.3273790530000239.273610495495749.4339011320566功能:求出成绩表中大于等于85的分数的算术平方根。(6) SELECT 2,3,POWER(2,3)氏列名氏列名氏列名) SELECT 2,3 POWER 12 3)| 辽门0功能:计算 2 的 3 次方。(7)SELECT YEAR(GETDATE(),MONTH(GETDATE(),DAY(GETDATE()功能:显示系统的年月日。2在studentsdb数据库中使用SELECT语句进行基本査询。(1) 在学生表中,查询每个学生的学号、姓名、出生日期信息SELECT学号姓名岀生日期FROM学生表|学号姓名出生日期10001刘卫平1900-10-01 00:00:00.00020002张为民1900-12-02 00:00:00.00030003马东1900-07-04 00:00:00.00040004钱达理1900-05-10 00:00:00.00050005东方枚1900-07-13 00:00:00.00060006郭文湫1930-06-04 00:00:00.00070007肖海燕1900-03-15 00:00:00.00000003张明华1900-04-16 00:00:00.000姓名家庭性址1张为民东阳市儿一北路2捋学号姓名10001刘卫平20002张为民30003马东40004钱达理50005东方枚60006郭文湫(2) 查询学号为 0002的学生的姓名和家庭住址。SELECT姓名家庭住址FROM学生表WHERE 学号i 0002 |(3) 找出所有男同学的学号和姓名。SELECT学号姓名FROM学生表WHERE性别=|男|3 使用SELECT语句进行条件査询(1) 在成绩表中查找分数在8090范围内的学生的学号和分数。SELECT学号分数FROH成绩表WHERE 分数汨口 AND 分数如口(2) 在成绩表中查询课程编号为C003的学生的平均分。SELECT AVG分数AS平均分FROM成绩表WHERE 课程编 1-=|00031I平均分丨1|79.333333在成绩表中查询学习各门课程的人数SELECT课程编号 COUNT (*) AS人数FROH成绩表GROUP BY慄程编号(4) 将学生按出生日期由大到小排序。SELECT学号 姓名岀生日期FROM学生表ORDER BY 出生日期 DESC学号姓名出生日期10002张为民1930-12-02 00:00:00.00020001刘卫平1900-10-01 00:00:00.00030005东方枚1900-07-13 00:00:00.00040003马东1900-07-04 00:00:00.00050006郭文斌1900-06-04 00:00:00.00060004钱达理1900-05-10 00:00:00.00070003张明华1900-04-16 00:00:00.00000007肖海燕1900-03-15 00:00:00.000(5) 使用 GROUP BY 查询子句列出个学生的平均成绩。(6) 查询所有姓“张”的学生的学号和姓名。提示:使用UNION运算符。(1 ocal). stu. . . LQueryl. sql* 摘要SELECT学号 姓名FROM学生表学号姓名0002張为民20003张明华Miil 11丿1WHERE 姓名 like 114嵌套查询(1)在学生表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。SELECT姓名岀生日期卩班顼学生表WHERE(SELECT 性别 FROH 学生表WHERE姓居“刘卫丰F姓名出生日期刘卫平1980-10-01 00:00:00.0002张为民1980-12-02 00:00:00.0003马东1980-07-04 00:00:00.0004钱达理1980-05-10 00:00:00.0005东方牧1980-07-13 00:00:00.0006郭文斌1980-06-04 00:00:00.000(2) 使用 IN 子查询查找所修课程编号为 C002 、 C005 的学生学号、姓名、性 别。SELECT学号姓名 性别FROM学生表WHERE 学号 IN(SELECT学号FROM成绩表WHERE 编号=0002 ANY (SELECT分数FROM成绩表WHERE 学号 i 0002 1 )(4) 列出学号为 0001 的学生的分数比学号为 0002 的学生的最高成绩还要高 的课程编号和分数。SELECT课程编号分数FROM成绩表WHERE 学号=00011 AND 分数 ALL| (SELECT分数FROM成绩表WHERE 学号=0002 1 )5连接查询(1)查询分数在8090范围内的学生的学号、姓名、分数。select学生表学号姓名成绩表疔数无匸咖 学空表inner join危绩表on学生表 学号 成绩表 学号 where 成绩表 分数 between 80 and 90学号姓若分数pc0001刘卫平0020001刘卫平9030001刘卫平8740001刘卫平8650002张为民0960003马东S370003马东04(2)查询学习“C语言程序设计”课程的学生的学号、姓名、分数。select学生表 学号 姓名成绩表 分数 仕5!学生表inner join成绩表on学生表学号成绩表学号inner join课程翁on应绩龛慄翟编号课程表课程编号 课程名林=1 c语言翟库i殳i+ 1学号姓名分数0001刘卫平902_0002张为民7330003马东73(3) 查询所有男同学的选课情况,要求列出学号、姓名、课程名称、分数。Q3060101VSQ. . . LQueryl. sql* 摘要select学生癡学号姓名课程表课程名称减绩表分数FROM学生表ER JOIN成绩表ON学生表学号=成绩表学号INNER JOIN课程裹ON危绩裹魂程编号=课程表课程编号 WHERE性别男| a|J结果消息学号姓名课程名称分数J_0001刘卫平犬学计算机基础8020001刘卫平匚语言程序设计9030001刘卫平SQL Serve遨据库及应用8740001刘卫平英语8650001刘卫平高等数学7860002张为民大学计算机基础7670002张为民匚语言程序设计7380002张为民SQL Serve遨据库及应用6790002张为民英语70100002张为民高等数学89110003马东犬学计算机基础83120003马东匚语言程序设计73130003马东SQLServer据库及应用84140003马东英语75150003马东高等数学65(4) 查询各门课程的最高成绩,要求列出课程编号、课程名称、分数。UJU6U1U1U_ _ _LUueryl_ sql* 洞多select课程衾慄程扁号;课程名称我绩表分数FROM课程表ER JOIN成绩表ON课程表课程编号=成绩表课程编号WHERE课程裹慄穫编号喊绩裹课翟编号and分薮=(select 分数)from 成绩表uh已匸已成绩表课翟编号魂翟表课程编号J结果消息课程编号课程名称分数0001大学计算机基础8320002匚语言程序设计9030003SQL Serve遨据库及应用8740004英语8650005高等数学89(5) 查询所有学生的总成绩,要求列出学号、姓名、总成绩。 提示:使用左外连接。Q3060101VSQ. . . LQueryl. sql* 摘要select学生衾学号姓居宀响分薮厂鬧总分FROM学生表丄已仇outer join成绩表on学生表 学号=成绩表 学号*口皿by学生表 学号赴名学号姓若总分0005东方牧NULL20006郭文斌NULL30001刘卫平42140003马东38050004钱达理NULL60007肖海燕NULL70003张明华NULL00002张为民375(6) 查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数。提示:使用右外连接。Q3060101SQ. . . LQuerrl. sql* 摘要select课程裹谯程编号:课程名称count (学生表学号as选祕人数FROM学生表right outer join成绩表on学生表学号成绩表学号right outer join课翟裹on咸绩裹漳翟编号课程表课程编号 事ciup by课程表慄程名称课翟裹课翟编号课程编号课程名称选修人数1 _0001大学计算机基础320002匚语言程序设计330003SQL Serve遨据库忑应用340004英语350005高等数学3(7) 查询所有没有选修课 C002 的学生信息,返回结果包括学号、姓名、性别。提示:使用条件运算符 EXISTS。yjuDuiu 丄-ujuery. sqx* 向立select学号姓盒性别FROM学生表WHERE NOT EXISTS(SELECT * FROH 成绩表WHERE学生表学号学号AND课程编号=0002)学号姓名性别J_0004钱达理男20005东方枚男30006郭文斌男40007肖海燕50003张明华(8) 在学生表和成绩表之间实现交叉连接。蟲leH率弄書喩鬆 课程编号;分数 FROM学生表 cross join 成绩表I学号课程編分数130001000384140001000475150001000565160002000180170002000290100002000387190002000486200002000578210002000176220002000273230002000367240002000470学号课程编分数2500020005092600020001S3270002000273200002000304290002000475300002000565310003000100320003000290330003000307340003000406350003000573360003000176学号课程编分数370003000273330003000367390003000470400003000589410003000183420003000273430003000384440003000475450003000565460004000180470004000290400004000387学号课程编分数4900040004065000040005705100040001765200040002735300040003675400040004705500040005095600040001S3570004000273530004000304590004000475600004000565学号课程编分数6100050001306200050002906300050003076400050004066500050005786600050001766700050002736300050003676900050004707000050005S37100050001S3720005000273学号课程编分数730005000304740005000475750005000565760006000100770006000290780006000387790006000486800006000573810006000176820006000273830006000367840006000470学号课程编分数0500060005090600060001S3070006000273000006000304S30006000475900006000565910007000180920007000290930007000307940007000406950007000570960007000176学号课程编分数学号课程編分数970007000273109000800048690000700036711000080005739900070004701110008000176100000700058911200080002731010007000183113000800036710200070002731140008000470103000700038411500080005891040007000475116000800018310500070005651170008000273106000800018011800080003841070008000290119000800047510300080003871200008000565(9)查询每个学生的所选课程的成绩,并列出学号生成分组汇总行 (总成绩) 和明细行(各课成绩)。提示:使用 SELECT 语句的 COMPUTE 选项。select学号分数FROM成绩表ORDER BY 学号 COMPUTE SUM 分数BY 学号学号分数学号I分数丨学号分数!10001801 ? 0002! 76J_0003S30001902 0002732000373300010730002673000304400010640002704000375500017850002095000365sumsumsum1421 1| 375J380 |
展开阅读全文