SQL-Customers Who Never Order
2016-04-29 15:57
337 查看
Suppose that a website contains two tables, the
Table:
Table:
Using the above tables as example, return the following:
way 1:
way 2:
Customerstable and the
Orderstable. Write a SQL query to find all customers who never order anything.
Table:
Customers.
+----+-------+ | Id | Name | +----+-------+ | 1 | Joe | | 2 | Henry | | 3 | Sam | | 4 | Max | +----+-------+
Table:
Orders.
+----+------------+ | Id | CustomerId | +----+------------+ | 1 | 3 | | 2 | 1 | +----+------------+
Using the above tables as example, return the following:
+-----------+ | Customers | +-----------+ | Henry | | Max | +-----------+
思路: way 1: 用嵌套子查询,适合多表格比较的情况。在Customers表中选择Id不在Orders表的CustomerId集合里面的元组 way 2: 用左外连接实现。首先要搞明白普通的连接功能是找到两个表格的公共集合然后形成新的表。 左外连接的关键词是left join或者left outer join,然后再加一个on,其实质就是一种构造基本表的方式 通过左外连接得到新的表后,再选出相应的元组即可
way 1:
select Name from Customers where Id not in ( select CustomerId from Orders )
way 2:
select Name from Customers as c left outer join Orders as d on c.Id = d.CustomerId where CustomerId is null
相关文章推荐
- SQL-Duplicate Emails
- SQL-Employees Earning More Than Their Managers
- sqlcmd相关
- centOS 7 安装nodeJs & mysql 常见问题
- mysql安全修改mysql数据库名几种方法
- MySQL数据库迁移(数据文件直接迁移)
- Redis+Keepalived高可用方案详细分析
- [精]Oracle 内存结构详解
- 利用redis + lua解决抢红包高并发的问题
- Bluemix的三台虚拟机做MongoDB Replica Set
- 定义常量类
- Redis安装及使用
- ios(六)sqlite3以及FMDB
- 【MySQL】查询保持IN中的顺序
- plsql oracle 无法解析指定的连接标识符
- SQL简单实用的优化方法
- Oracle RAC 环境下的连接管理
- SQL 1:常用SQL语句
- SQL 1:常用SQL语句
- MySQL监控工具之innotop