登录
首页 >> 生肖星座 >> 十二生肖

case表达式的作用

小神仙 2023-08-11 13:28:37









多表查询:从多表中获取数据;









两个表的结构是一样的,但是红框的数据是不同的。利用表的加法将两个表合并成一个表;


表的加法(union)根据行合并两个表的数据,删除重复数据;








要保留重复数据,请使用union all









1)什么是联结?


关系是数据库可以对应的匹配,在关系数据库中称为连接(join);


连接是通过表与表之间的关系将表合并在一起的操作;








学生表-成绩表 通过学号连接;成绩表-课程表 通过课程号连接;课程表-教师表 通过教师号联系;


2)常见的连接方式








①交叉连接(笛卡尔积)


将表中的每一行与另一行合并;


如图:表1、表2、表3分别和A、B合并在一起;


新表行数=表1行数*表2行数。








在实际工作中使用的交叉联系较少,结果行数过多,需要大量的运算成本和设备的支持,


而且行数过多,实际价值有限;


但是,交叉连接是后面所有连接的基础,其他连接是在交叉连接的基础上+过滤条件。


②内联结(inner join)


两张表中的数据同时存在于搜索中








内部联系的操作:从学生表和成绩表中取出合格的行 → 交叉联结;


内联SQL语句:



③左联结(left join)


找出表中左侧的所有数据,左连接是下图中的红色部分;








左连接操作:通过学号产生匹配关系。左连接将以左表为主表,读取所有数据(学生表中的所有数据都取出)。右表只取学号相同的数据,然后交叉组合;


左联系SQL语句:



如何连接下图中的句子,只保留红色区域








左联+where句子句子








④右联结(right join)


右表中的数据全部取出,右0005左表中没有相应的数据,显示nulll








右连接的操作:通过学号产生匹配关系,读取右表的所有数据(取出成绩表的所有数据),左表只取学号相同的数据,然后交叉组合并;


SQL语句右联:



在右联结的基础上,去除重叠部分














⑤全联结(full join)


返回左表和右表的所有行。当一行与另一行数据匹配时,两行合并。如果没有匹配线,则填充相应的空值,my sql不支持全联系;














SQL 总结联结方式









翻译成白话,写出分析思路,写出相应的sql语句;


问题1:查询所有学生的学号、姓名、选课数、总分


1)学号、姓名(学生表) student)


2)选课数量(每个学生选课数量:成绩表score,按学号分组,计算课程号)


3)总分(每个学生总分:成绩表 score,按学号分组,成绩求和sum)



问题2:查询所有平均成绩大于85的学生的学号、姓名和平均成绩


1)查询所有学生的学号、姓名和平均成绩;学号、姓名(在学生表中);


平均分数(每个学生的平均分数:在分数表中,按学号分组,平均分数:avg(成绩));


2)平均成绩>85



问题3:查询学生选课情况:学号、姓名、课程号、课程名称


1)学号,姓名在学生表上(student)


2)课程编号,课程名称在课程表中(course)


学生表格与课程表格有关,需要通过成绩表建立关系










case whenthen


whenthen


whenthen


...


else


end


1)case表达式的作用


当有多种情况需要判断时,需要使用case表达式;


它可以帮助我们解决复杂的查询问题。case表达的功能相当于判断每一行是否满足某一条件的条件判断函数;


如何满足某一条件,操作后面的then子句,如果不符合条件,继续操作when子句。如果您没有找到合适的数据,您将访问else子句。


2)问题1:









运行顺序:


第一步:先操作>=60、满意后,显示合格,end;


第二步:运行

Switch case 语句怎么使用

switch case用法详解:

1、switch是“开关”的意思,它也是一种“选择”语句,但它的用法非常简单。

2、switch是多分支选择语句。说得通俗点,多分支就是多个if。

从功能上说,switch语句和if语句完全可以相互取代。但从编程的角度,它们又各有各的特点,所以至今为止也不能说谁可以完全取代谁。

3、当嵌套的if比较少时(三个以内),用if编写程序会比较简洁。但是当选择的分支比较多时,嵌套的if语句层数就会很多,导致程序冗长,可读性下降。因此C语言提供switch语句来处理多分支选择。所以if和switch可以说是分工明确的。在很多大型的项目中,多分支选择的情况经常会遇到,所以switch语句用得还是比较多的。

4、switch的一般形式如下:

switch(表达式)

{

case常量表达式1:语句1

case常量表达式2:语句2

case常量表达式n:语句n

default:语句n+1

}


扩展资料: 说明:

1)、switch后面括号内的“表达式”必须是整数类型。也就是说可以是int型变量、char型变量,也可以直接是整数或字符常量,哪怕是负数都可以。但绝对不可以是实数,float型变量、double型变量、小数常量通通不行,全部都是语法错误。

2)、switch下的case和default必须用一对大括号{}括起来。

3)、当switch后面括号内“表达式”的值与某个case后面的“常量表达式”的值相等时,就执行此case后面的语句。执行完一个case后面的语句后,流程控制转移到下一个case继续执行。如果你只想执行这一个case语句,不想执行其他case,那么就需要在这个case语句后面加上break,跳出switch语句。

再重申一下:switch是“选择”语句,不是“循环”语句。很多新手看到break就以为是循环语句,因为break一般给我们的印象都是跳出“循环”,但break还有一个用法,就是跳出switch。

4)、若所有的case中的常量表达式的值都没有与switch后面括号内“表达式”的值相等的,就执行default后面的语句,default是“默认”的意思。如果default是最后一条语句的话,那么其后就可以不加break,因为既然已经是最后一句了,则执行完后自然就退出switch了。

5)、每个case后面“常量表达式”的值必须互不相同,否则就会出现互相矛盾的现象,而且这样写造成语法错误。

6)、“case常量表达式”只是起语句标号的作用,并不是在该处进行判断。在执行switch语句时,根据switch后面表达式的值找到匹配的入口标号,就从此标号开始执行下去,不再进行判断。

7)、各个case和default的出现次序不影响执行结果。但从阅读的角度最好是按字母或数字的顺序写。

8)、当然你也可以不要default语句,就跟if…else最后不要else语句一样。但最好是加上,后面可以什么都不写。这样可以避免别人误以为你忘了进行default处理,而且可以提醒别人switch到此结束了。

c++ switch case 的用法

switch (x/1000)
{
case 0:
cout << x << endl;
break;
case 1:
cout << x * 0.9 << endl;
break;
}

说明:
switch语句的执行
1,对switch中的控制表达式进行求值。这里是对x/1000求值,如果0<=x<1000,求值结果为0,如果1000<=x<2000,结果为1

2,根据控制表达式的求值结果,跳转到相应的case入口,向后执行。注意是向后执行到整个switch语句之外,而不是只执行这一个case中包括的语句。通常只需要执行一个case语句,这需要通过goto,return,break,continue等语句来转移到switch之外。这里用的是break语句,如果把第一个break去掉,而的范围又在0-1000之间,这时不但会输出x,还会执行下一个case语句,输出 0.9*x。

3,如果控制表达式的求值结果不等于任何的case入口,则会转移到default语句(如果有的话,没有就结束了)。比如这里还可以加入一个default语句来处理x<0或x>2000的情况
default:
cout << "你输入的数据不合法 " << endl;
break;
注意,default,不一定要放在所有的case语句之后,也可以放中间或开始的,但通常都放最后,比较符合习惯,所以如果放最后break可以省略。同理上面程序中的第二个break可以省略,但是这不是一个好的编程习惯,假如你在以后要在程序中加入一个 case 2的话,就很可能会把break可忘了。

其实default可以看成一个特殊的case语句,它的用法和case是一样,只是它能匹配所有case入口之外的其余情况。

PS: 我所有的回答都是自己手工输入,认真回答的,不是胡乱粘贴的。满意的话给个最佳吧

本文地址:http://www.dadaojiayuan.com/shiershengxiao/72888.html.

声明: 我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理,本站部分文字与图片资源来自于网络,转载是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们(管理员邮箱:douchuanxin@foxmail.com),情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!

上一篇:

下一篇:

相关文章