Mysql 查询技巧:使用JOIN优化子查询
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Mysql 查询技巧:使用JOIN优化子查询,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1731字,纯文字阅读大概需要3分钟。
内容图文
1.数据准备
mysql> select * from student;
+----+--------+----------+---------+-------------+
| id | name | idCardNo | isCadre | nickname |
+----+--------+----------+---------+-------------+
| 1 | Tom | 350020 | 1 | Big T |
| 2 | Jim | 350022 | NULL | PP |
| 3 | Lucy | 460311 | NULL | Little girl |
| 4 | Liming | 733098 | 1 | NULL |
+----+--------+----------+---------+-------------+
mysql> select * from cadre;
+----+--------+----------+-----------+
| id | name | idCardNo | nickname |
+----+--------+----------+-----------+
| 1 | Tom | 350020 | Last Tom |
| 2 | Max | 636095 | Hand |
| 3 | Liming | 733098 | China Boy |
+----+--------+----------+-----------+
要求:查询出student表中所有人员信息及其在cadre表中的nickname
① 子查询方式
SELECT a.idcardNo, a.name, a.nickname, (SELECT b.nickname FROM cadre b WHERE b.name=a.name) AS nickname_b FROM student a;
+----------+--------+-------------+------------+
| idcardNo | name | nickname | nickname_b |
+----------+--------+-------------+------------+
| 350020 | Tom | Big T | Last Tom |
| 350022 | Jim | PP | NULL |
| 460311 | Lucy | Little girl | NULL |
| 733098 | Liming | NULL | China Boy |
+----------+--------+-------------+------------+
子查询的方式中,针对student表的每条记录都会对cadre表进行一次查询,效率较低。
② 使用JOIN优化方式
SELECT a.idCardNo, a.name, a.nickname, b.nickname FROM student a LEFT JOIN cadre b ON a.name=b.name;
+----------+--------+-------------+-----------+
| idCardNo | name | nickname | nickname |
+----------+--------+-------------+-----------+
| 350020 | Tom | Big T | Last Tom |
| 733098 | Liming | NULL | China Boy |
| 350022 | Jim | PP | NULL |
| 460311 | Lucy | Little girl | NULL |
+----------+--------+-------------+-----------+
原文:http://www.cnblogs.com/techroad4ca/p/5738643.html
内容总结
以上是互联网集市为您收集整理的Mysql 查询技巧:使用JOIN优化子查询全部内容,希望文章能够帮你解决Mysql 查询技巧:使用JOIN优化子查询所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。