SQL如何模拟xor?

栏目: 数据库 · 发布时间: 7年前

内容简介:我想知道是否有人可以帮助我解决我在面试时遇到的这个问题.假设我有两个表:问题是编写一个SQL查询,它将返回table1或table2中的所有行,但不能同时返回两者,即:我以为我可以做一些完整的外部联接:

我想知道是否有人可以帮助我解决我在面试时遇到的这个问题.假设我有两个表:

table1                 table2
------------           -------------
id | name              id | name
------------           -------------
 1 | alpha              1 | alpha
 3 | charlie            3 | charlie
 4 | delta              5 | echo
 8 | hotel              7 | golf
 9 | india

问题是编写一个 SQL 查询,它将返回table1或table2中的所有行,但不能同时返回两者,即:

result
------------
id | name
------------
 4 | delta
 5 | echo
 7 | golf
 8 | hotel
 9 | india

我以为我可以做一些完整的外部联接:

SELECT table1.*, table2.* 
FROM table1 FULL OUTER JOIN table2 
ON table1.id=table2.id 
WHERE table1.id IS NULL or table2.id IS NULL

但这给了我一个关于SQL Fiddle的语法错误(我不认为它支持FULL OUTER JOIN语法).除此之外,我甚至无法找到一种方法来连接两个表的行,更不用说过滤掉两个表中出现的行.有人可以启发我,告诉我该怎么做?谢谢.


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

一路编程

一路编程

史蒂夫·富特 (Steven Foote) / 佟达 / 电子工业出版社 / 2017-1-1 / CNY 65.00

《一路编程》是一本编程入门书籍,然而,如果以书中所讲内容作为入门标准,估计十有八九的在职程序员都不能算已入门。现代软件开发,已经不仅仅是写出正确的代码这么简单,环境、依赖、构建、版本、测试及文档,每一项都对软件是否成功交付起到至关重要的作用,这些都是每一个程序员在开发软件过程中必备的技能。《一路编程》对于上述的每一种技能都做了简洁而精练的介绍,以满足最基本的日常软件开发。换句话说,《一路编程》实际......一起来看看 《一路编程》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器