当子查询碰上NULLUNIONJOIN总结

情景:

现在有如图两个表,boy和girl,对应着Boy和Girl两个bean,有共同字段id、name,另外boy还有个外键grilfriend(指向girl的id)

现在要查询所有的Boy,如果有girlfriend的话就把girl的name也取出来,赋值给boy.girl.name

我写了一条SQL:”SELECT  b.name,g.name FROM boy b , girl g  WHERE g.id=b.girlfriend;”

问题:

因为有的boy有girlfriend,有的boy没有girlfriend,所以那些没有girlfriend的boy就不能跟girl表关联起来了

这样子查询只能查询出有girlfriend的boy

解决方案:

UNION将SQL改成如下:

“SELECT b.name,g.name FROM boy b, girl g WHERE (b.girlfriend=g.id) and (isnull(b.girlfriend)=0) UNION b.name,”null” from boy b where isnull(b.girlfriend)=1;”

利用组合查询

先判断boy.girlfriend存在与否,如果存在就取出bou.girlfriend.name,否则就不取出

JOIN

将SQL改成如下:

“SELECT boy.id,boy.name,girl.name FROM boy LEFT JOIN girl ON girl.id=boy.girlfriend;”

联合查询

总结

用JOIN的效率比用UNION要高,因为UNION相当于查询两次,JOIN是SELECT的时候先判断一下

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏乐沙弥的世界

SQL基础-->分组与分组函数

使用group by column1,column2,..按columm1,column2进行分组,即column1,column2组合相同的值为一个组

15820
来自专栏乐沙弥的世界

批量 SQL 之 FORALL 语句

    对PL/SQL而言,任何的PL/SQL块或者子程序都是PL/SQL引擎来处理,而其中包含的SQL语句则由PL/SQL引擎发送SQL语句转交到SQL引擎...

9220
来自专栏Java 源码分析

数据库Exists关键字举例

一.问题描述: 查询所有未选择03号课程的学生的姓名 规定使用存在量词 student表: ? grade表: ? 二.思路: 既然是存在量词那么也就是E...

30660
来自专栏C# 编程

1 - SQL Server 2008 之 使用SQL语句创建具有约束条件的表

约束条件分为以下几种: 1)非空约束,使用NOT NULL关键字; 2)默认值约束,使用DEFAULT关键字; 3)检查约束,使用CHECK关键字; 4)唯一约...

21000
来自专栏程序员宝库

MYSQL 业务上碰到的 SQL 问题整理集合

前言 身为一名前端工程师,对于 SQL了解程度并不是很深刻,盘点一些个人工作遇到的问题,给大家普及下知识,以及记录自己如何解决这些问题的。 导航 SELECT ...

34560
来自专栏机器学习算法与Python学习

SQL Server 学习笔记

之前学过一点数据库但由于一直没有使用忘得差不多了,最近重新复习一下相关的知识,把基本的语法YOU又看了一遍,为了强化记忆在写一遍~~~~~~ ? 基本的 se...

384150
来自专栏跟着阿笨一起玩NET

SQL小技巧总结。

14410
来自专栏PHP在线

mysql

cross join :笛卡尔交集。 Inner join :内连接。 left join :只要满足左边表的需求就可以了,右表有无都可以。 right ...

37380
来自专栏码农分享

数据库批量删除

24930
来自专栏性能与架构

mysql 索引无效的情况

下面几种情况下,索引是不会被使用的 (1)组合索引,查询时的条件列不是组合索引中的第一个列 例如 组合索引 (a,b),查询中使用了b作为查询条件,这时是不会用...

44770

扫码关注云+社区

领取腾讯云代金券