- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
PAGE7
教案首页
课程名称
MySQL数据库开发
本节课题
任务3.4case表达式和控制流函数
授课方式
理实一体化
教学参考及教具
姜云桥主编.MySQL数据库开发.临科院:教务处,2023
计算机MySQL数据库软件多媒体教学系统资料包
教学目标及基本要求
熟练使用CASE表达式完成各种查询
能利用控制流函数完成各种查询
能使用CASE表达式完成数据的更改
掌握CASE表达式的两种语法
掌握CASE表达式在select、groupby、orderby、UPDATE等语句的使用。
掌握IF、IFNULL控制流函数的使用。
教学重点
教学难点
CASE增删改操作
CASE表达式和控制流函数的使用
教学小结
作业及要求
按照任务书做好预习任务
对数据库jxgl6张表进行增删改操作
教后反思
注意:用微课视频每个典型操作做示范
教案用纸
教学内容、方法和过程
附记
任务3.4CASE表达式和控制流函数
【任务要求】
对数据库jxgl中的student(学生信息表)、course(课程表)、score(成绩表)、departments(院系单位表)、teacher(教师表)和teach(讲授表)6张表进行增删改操作。
【任务必备知识】
3.4.1CASE表达式
CASE表达式是MySQL中非常重要的技术,通过它可以巧妙的实现一些查询,本节将通过几个常见需求来学习该表达式的使用。CASE表达式有两种语法形式,一种时简单CASE表达式,另外一种是搜索CASE表达式。
一、简单case表达式
简单case表达式类似Java中的switch结构,语法格式如下:
caseexpression
whenvalue1thenresult1
whenvalue2thenresult2
...
elseresult
end
执行流程图如下所示:
二、搜索CASE表达式
case
whencond1thenresult1
whencond2thenresult2
...
elseresult
end
执行流程图如下所示:
三、CASE表达式的使用
1.select语句中使用CASE表达式
【任务3.4.3】通过搜索CASE表达式的方式显示任务3.4.1。
mysqlselects_name,casewhens_sex=男then1else2endas性别
-fromstudent
-wheres_namelike张%;
+++
|s_name|性别|
+++
|张群|1|
|张平|1|
|张早|1|
|张东妹|2|
+++
2.利用CASE表达式完成行列转换
【任务3.4.4】行列转换,查询学生表student,统计各系男、女生人数。
mysqlselectd_no,
-sum(casewhens_sex=男then1else0end)asm_count,
-sum(casewhens_sex=女then1else0end)asf_count
-fromstudent
-groupbyd_no;
++++
|d_no|m_count|f_count|
++++
|D001|7|0|
|D002|3|1|
|D003|2|1|
|D005|0|2|
|D006|0|1|
++++
3.GROUPBY子句使用CASE表达式
【任务3.4.5】查询成绩表score,统计优秀数、良好数、及格数、不及格数,90~100为优秀,80~89为良好,60~79为及格,0~59为不及格。
mysqlselectcasewhenmark=90then优秀
-whenmark=80then良好
-whenmark=60then及格
-else不及格
-endaslevel,count(*)
-fromscore
-groupbylevel;
+++
|level|count(*)|
+++
|良好|
文档评论(0)