MySQL关联查询总结
MySQL中经常使用关联查询,有机会总结下:
1 left join(左联查询):
返回包括左表中的所有记录和右表中联接字段相等的记录
例:select * from a left join b on a.id=b.id
2 right join(右联查询):
right join(右联接)返回包括右表中的所有记录和左表中联接字段相等的记录
例:select * from a right join b on a.id=b.id
看到这里可能比较还是有点不明白,请看以下示例
假如有两张表,A B
表A记录如下:
aID aNum
1 a20050111
2 a20050112
3 a20050113
4 a20050114
5 a20050115
表B记录如下:
bID bName
1 2006032401
2 2006032402
3 2006032403
4 2006032404
8 2006032408
执行select * from A left join B on A.aID = B.bID
结果如下:
aID aNum bID bName
1 a20050111 1 2006032401
2 a20050112 2 2006032402
3 a20050113 3 2006032403
4 a20050114 4 2006032404
5 a20050115 NULL NULL
结果:从查询结果可以看出左关联查询是以左表的表为主表进行查询,由于A表中aID为5的在右表中没有对应记录,因此查询结果中最后一行又两个NULL列,同理可以得出右关联的原理。
3 内联查询(联接查询):在where子句中指定条件,将多个表连接起来
select c.cname,b.bookname from cats c,book b, where c.id=b.catid
看到这里,可能不禁发问,这三者有什么区别?看下面这个例子
有两张数据表,表user(id, name)记录了用户的ID和昵称,表article(id,uid,title, content, time)记录了用户发表的文章标题.内容和时间,写一个SQL语句打印出每个用户的昵称及其发表的文章总数
解决方法1:
select u.name,count(a.id) from user u,article a where u.id=a.uid group by a.uid
解决方法2:
select u.name,count(a.id) from user u left join article a on u.id=a.uid group by a.uid
假如出现这种情况:有一个用户没有发表文章,那么第一个解决方案不会出现这个用户,因此第一种是错误的。
4嵌套查询
在一个select语句的where子句中,包含另一个select子句,也可称为子查询。嵌套查询的原理一般是由里向外。
例:select bookid,bookname from books where bookid in(select bookid from cats );
最近做面试题,碰到几个比较有意思的Mysql操作,总结如下:
a)关系S(s#, sname, sex), C (c#, cname), SC(s#, c#) . 其中S#为学生号,sname为学生姓名,sex为性别,c#为课程号,cname为课程名。
写出查询选修"计算机"课的全体女学生姓名的SQL语句。
select S.s#,S.sname from S,SC where S.s#=SC.s# and S.sex=1 and SC.c# in (select from C where cname='计算机' )
写出查询没有选修"数学"课的学生姓名的SQL语句。
select * from S where s# not in(select from S,SC where S.s#=SC.s# and SC.c# in ( select c# from C where cname='数学'))
b)列三张表,请根据要求写出SQL语句
CARD借书卡。 CNO卡号,NAME姓名,CLASS班级
BOOKS图书。 BNO书号,BNAME书名,AUTHOR作者,PRICE单价
BORROW借书记录。 CNO借书卡号,BNO书号,RDATE还书日期
备注:限定每人每种书只能借一本
找出借书超过5本的读者,输出借书卡号,及所借图书册数。(5分)
错误写法: select c.name, count(b.cno) total from card c,borrow b where c.cno=b.cno and total>5 group by b.cno ;
正确写法:select c.name, count(b.cno) total from card c,borrow b where c.cno=b.cno group by b.cno having total>=5;
由于使用的是group进行分组,而在group by进行分组查询统计后,只能使用having子句来对查询结果进行进一步的过滤。
MySQL关联查询总结的更多相关文章
- mysql 关联查询 索引不起作用原因记录
业务逻辑如下:查询某篇文章的评论列表,且列出评论人及被评论人的昵称.头像. 先看一下表结构 评论表: 评论表的索引: 用户表: 用户表的索引: 查询语句如下: SELECT t1.comment_id ...
- mysql关联查询和联合查询
一.内联方式 1.传统关联查询 "select * from students,transcript where students.sid=transcript.sid and transc ...
- MySQL☞关联查询
关联查询:所需要的数据来源于多张表,通过表的连接查询(关联查询)来查询多张表中的数据 格式: select 别名1 . */列名 , 别名2 . */列名 from 表名1 别名1 , 表名2 别 ...
- mysql 关联查询技巧
废话不多说,直接进入正题 #数据准备 班级表class: CREATE TABLE `class` ( `class_no` ) unsigned zerofill NOT NULL AUTO_INC ...
- [mysql] 关联查询sql记录
//查询账单关联订单 select o.id as id, o.order_no as orderNo, o.case_no as caseNo, o.send_time as sendTime, o ...
- MySQL 关联查询 内连接
内连接 [INNER| CROSS] JOIN无条件内连接:无条件内连接,又名交叉连接/笛卡尔连接第一张表种的每一项会和另一张表的每一项依次组合#例:mysql> select * ...
- mysql关联查询
mysql数据库的统计------生成统计信息 1.distinct:在一组之中将各个唯一的值找出来,如找出所有的品牌种类 mysql>select distinct brand_kind fr ...
- mysql 关联查询的执行顺序
STRAIGHT JOIN : 能强制按照顺序关联表(应该是)
- MySQL 关联查询 外连接 { LEFT| RIGHT } JOIN
左外连接: (以左表为基准)两张表做连接的时候,在连接条件不匹配的时候留下左表中的数据,而右表中的数据以NULL填充例:使用左连接把学生的数据全取出来,该学生没有学院信息的用NULL填充 mysql& ...
随机推荐
- PHP和MySQL Web开发 原书第4版 高清文字版,有目录,附带源码
PHP和MySQL Web开发 原书第4版:http://yunpan.cn/QCWIS25zmYTAn 提取码 fd9b PHP和MySQL Web开发 原书第4版源码:http://yunp ...
- Windows Phone 8.1 多媒体(1):相片
原文:Windows Phone 8.1 多媒体(1):相片 Windows Phone 8.1 多媒体(1):相片 Windows Phone 8.1 多媒体(2):视频 Windows Phone ...
- java设计模式之九外观模式(Facade)
外观模式是为了解决类与类之家的依赖关系的,像spring一样,可以将类和类之间的关系配置到配置文件中,而外观模式就是将他们的关系放在一个Facade类中,降低了类类之间的耦合度,该模式中没有涉及到接口 ...
- 第3章2节《MonkeyRunner源码剖析》脚本编写示例: MonkeyDevice API使用示例(原创)
天地会珠海分舵注:本来这一系列是准备出一本书的,详情请见早前博文“寻求合作伙伴编写<深入理解 MonkeyRunner>书籍“.但因为诸多原因,没有如愿.所以这里把草稿分享出来,所以错误在 ...
- C程序中引用自定义的C函数模块
原文:C程序中引用自定义的C函数模块 我们知道,刚开始接触C语言编程,一般都是在一个.c或者.cpp(以下只说.c)的文件中编写代码,其中一定会有一个入口函数, 也就是main()函数,你可以将程序代 ...
- Monkey源码分析之事件源
上一篇文章<Monkey源码分析之运行流程>给出了monkey运行的整个流程,让我们有一个概貌,那么往后的文章我们会尝试进一步的阐述相关的一些知识点. 这里先把整个monkey类的结构图给 ...
- SQL Server相似度比较函数
原文:SQL Server相似度比较函数 相似度函数 概述 最近有人问到关于两个字段求相似度的函数,所以就写了一篇关于相似度的函数,分别是“简单的模糊匹配”,“顺序匹配”,“一对一位置匹配”.在 ...
- 使用 C# 进行 Outlook 2007 编程
原文:使用 C# 进行 Outlook 2007 编程 探讨如何使用 C# 编程语言生成 Outlook 识别的应用程序和 Outlook 外接程序. 请从"Add References&q ...
- android 删除SD卡或手机的缓存图像和文件夹
public static final String TEMP_PHOTO_FILE_NAME = "temp_photo.jpg"; private static String ...
- return 使用和闭包
1.return 使用 案例一: var a=1; for(var b=0; b<10; b++){ return b; }; sonsole.log(b)//返回为空 个人认为此处左右与为全局 ...