多表查询:从多表中获取数据;
两个表的结构是一样的,但是红框的数据是不同的。利用表的加法将两个表合并成一个表;
表的加法(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用法详解:
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到此结束了。
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),情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!
上一篇: 十二生肖中最好的婚姻配对
下一篇: 男女最佳婚配大全