数据库中子查询,联结查询,组合查询的用法和异同

子查询

我们一般情况下会把数据分解后分别存储在不同的表中,使得数据库的表满足第三范式,避免存取重复的数据,但是在查询过程中,我们需要一次性查询不同的表,相关或者无关的数据,这时候就需要使用到联结查询或者子查询。我们先来看看什么是子查询。
子查询是嵌套在另一个查询语句中的查询。
让我们看一个查询的样例:

SELECT * FROM table1 WHERE column1 = (SELECT column1 FROM table2);

上面的例子我们可以看到SELECT * FROM table1 是外层的查询,SELECT column1 FROM table2是子查询。

子查询的好处:

  • 可以在查询过程中以其他表的相关内容作为条件。
  • 比起复杂的联结查询和组合查询提供了可替代的方法。
  • 子查询相对于联结查询和组合查询更容易理解,有比较清晰的结构。
    例子:
    有下面三个表:
    学生表:


    image.png

    成绩表:


    image.png

    学科表:
    image.png

    要求:
    查找年龄为18的学生的语文成绩:
SELECT score from score where student_id = (select id from student where age = 18) and subject_id = (select id from subject where subject = "语文");

结果:



但是子查询也有相应的缺点:

  • 当查询的表过多,嵌套的层数变多都会使查询语句变得复杂,可读性也会变差。
  • 子查询的结构是从里层到外层,里层的结果在语句的其他部分不可用,性能较差,查询范围也会受限。

联结查询

看了上面的子查询后再来了解另外一种可以进行多表查询的方式:
联结查询可以代替子查询进行跨表查询,效率会明显提高。
我们看一下联结查询的不同形式:

内联结:

内联结是将一个表中的行与其他表中的行进行匹配,得到两个表的交集。
内联结的语法如下:

SELECT column_list FROM table1 
INNER JOIN t2 ON join_condition1
(INNER JOIN t3 ON join_condition2)
...WHERE conditions

例如联结学生表和成绩表,查出姓名为小花的成绩信息:

SELECT * FROM score INNER JOIN student ON score.student_id = student.id WHERE student.name = "小花";

结果:


image.png

外联结

外联结有左外联结和右外联结

  • 左外联结
    左外联结将左表作为主表,如果联结的两个表的连接条件匹配,则此行会包含在结果集中,如果左表(主表)中的行与右边中的行不匹配,则会将左边中的行放在结果集中并将右边中的字段都由null填充放入该行
    例如:
    查询所有学生学科成绩信息:
  1. 当学生表为主表:
SELECT * FROM student LEFT JOIN score ON student.id = score.student_id;

结果:


image.png
  1. 当score表为主表:
SELECT * FROM score LEFT JOIN student ON student.id = score.student_id;

结果:


image.png

组合查询

组合查询将多个select语句中的两个或者多个结果集合并到一个结果集中。
组合查询语法:

SELECT column_list
UNION [DISTINCT | ALL]
SELECT column_list
UNION [DISTINCT | ALL]
...

要使用UNION运算符组合两个或多个查询结果的结果集时必须满足以下条件:

  • 所有SELECT语句中出现的列的数量和顺序都必须相同。
  • 列的数据类型必须相同或者可转换

默认情况下,如果未指定运算符,UNION运算符也会删除重复的行。
比如:
将custom表和employee表组合起来,custom和employee表都只有id,name两个字段。

CREATE TABLE employee (
    id INT NOT NULL,
    name VARCHAR(100) NOT NULL
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO employee VALUES(1,"Molly"),(2,"Micheal"),(3,"John");
CREATE TABLE custom (
    id INT NOT NULL,
    name VARCHAR(100) NOT NULL
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO custom VALUES(12,"Mick"),(16,"Susan");

组合查询:

SELECT id,name FROM employee UNION SELECT id,name FROM custom;

结果:


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容