sql 语句系列(多表之链二)[八百章之第四章]

从多个表中返回缺失值

比如说查询每个员工的部门,且查看部门的所有员工。

这里考虑一种情况就是可能有部门没有员工,同样有些员工还没有分配部门。
解析使用 full outer join.

select d.DEPTNO,d.DNAME,e.ENAME
from DEPT d full outer join EMP e 
on (d.DEPTNO=e.DEPTNO)

在运算中比较null

因为null值是不能比较的,那么可以把null值转换为0;

select ename,comm
from EMP
where coalesce(COMM,0)<(select comm from EMP where ename='WARD')

coalesce返回一个传入参数的非空值。

如果我们使用coalesce,像这样:

select ename,comm
from EMP
where COMM<(select comm from EMP where ename='WARD')

那么就会自动排除null项。

posted @   敖毛毛  阅读(130)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示