欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql連接查詢、聯(lián)合查詢、子查詢?cè)砼c用法實(shí)例詳解

 更新時(shí)間:2020年04月15日 11:30:07   作者:隨風(fēng)行云  
這篇文章主要介紹了mysql連接查詢、聯(lián)合查詢、子查詢?cè)砼c用法,結(jié)合實(shí)例形式詳細(xì)分析了mysql連接查詢、聯(lián)合查詢、子查詢的基本概念、功能、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了mysql連接查詢、聯(lián)合查詢、子查詢?cè)砼c用法。分享給大家供大家參考,具體如下:

本文內(nèi)容:

  • 連接查詢
  • 聯(lián)合查詢
  • 子查詢
    • from子查詢
    • where子查詢
    • exists子查詢

首發(fā)日期:2018-04-11


連接查詢:

  • 連接查詢就是將多個(gè)表聯(lián)合起來查詢,連接查詢方式有內(nèi)連接、外連接、自然連接、交叉連接。連接查詢使得可以同時(shí)查看多張表中數(shù)據(jù)。
    • 內(nèi)連接:有條件連接,多個(gè)表之間依據(jù)指定條件連接,匹配結(jié)果是保留符合匹配結(jié)果的記錄。
    • 外連接:與內(nèi)連接不同的是不管匹配符不符合都保留,根據(jù)外連接連接方式來決定保留哪張表,比如保留左表的話,那么左表無法匹配右表時(shí),保留左表數(shù)據(jù),然后置右表字段數(shù)據(jù)為null.
    • 自然連接:有條件連接,自動(dòng)依據(jù)“同名字段”連接(多個(gè)同名字段就都作為條件)。
    • 交叉連接cross join:無條件連接,將每一條記錄與另外一個(gè)表的每一條記錄連接(笛卡爾積),結(jié)果是字段數(shù)等于原來字段數(shù)之和,記錄數(shù)等于之前各個(gè)表記錄數(shù)之乘積。
-- 實(shí)驗(yàn)表結(jié)構(gòu)
create table student(
id int,
name varchar(15),
gender varchar(15),
cid int
);
create table class(
cid int,
cname varchar(15)
);
drop table student,class;
-- 實(shí)驗(yàn)表數(shù)據(jù):
insert into student values(1,"lilei","male",1),(2,"hanmeimei","male",2),(3,"jack","male",1),(4,"alice","female",4); --這里特意創(chuàng)建了一個(gè)class中沒有的4
insert into class values(1,"linux"),(2,"python"),(3,"java"),(5,"html5");--這里特意創(chuàng)建了一個(gè)student中沒有的5
select * from student;
select * from class;

imageimage

內(nèi)連接:

  • 從左表中取出每一條記錄,去右表中與所有的記錄進(jìn)行匹配,保留匹配成功的記錄,并將兩份記錄拼接。
  • 語法:select 字段列表 from 左表 [inner] join 右表 on 左表.字段 = 右表.字段;
    • 不使用on條件的時(shí)候,結(jié)果與交叉連接相同
    -- 內(nèi)連接
    -- select * from student inner join class; --結(jié)果與交叉連接相同
    select * from student join class on student.cid = class.cid;
    select * from student inner join class on student.cid = class.cid;
    image

外連接:

  • 與內(nèi)連接不同的是主表記錄不管匹配符不符合都保留,方式有左外連接、右外連接,左外連接是保留左表,右外連接是保留右表
  • 語法:
    • 左外連接:select 字段列表 from 左表 left join 右表 on 左表.字段 = 右表.字段;
    • 右外連接:select 字段列表 from 左表 right join 右表 on 左表.字段 = 右表.字段;
    select * from student left join class on student.cid = class.cid;
    image
    select * from student right join class on student.cid = class.cid;
    image

自然連接:

  • 自動(dòng)匹配連接條件,系統(tǒng)以字段名字作為匹配模式(同名字段就作為條件,多個(gè)同名字段就都作為條件)
    • 自然內(nèi)連接:類似內(nèi)連接,但不提供連接條件。
    • 自然外連接:類似外連接,但不提供連接條件。
  • 語法:
    • 自然內(nèi)連接:select 字段列表 from 表名 natural join 表名;
    • 自然外連接:select 字段列表 from 表名 natural left\right join 表名;
    select * from student natural join class;
    image
    select * from student natural left join class;
    image

交叉連接:

  • 將每一條記錄與另外一個(gè)表的每一條記錄連接
  • 語法:
    • select 字段列表 from 表名 cross join 表名;
    • select 字段列表 from 表名 ,表名;
    select * from student cross join class;
    select * from student,class;
    image

補(bǔ)充:

  • 在多個(gè)表中,為了區(qū)分每個(gè)表,以及簡(jiǎn)便使用,可以使用表別名。
      select * from student inner join class on student.cid = class.cid;-- 原本結(jié)果
      select id,name,gender,c.cid,cname from student as s inner join class as c on s.cid = c.cid;-- 使用表別名
  • 可以多重連接。
  • 外連接可以模擬自然連接,只需要將連接條件on 左表.字段 = 右表.字段變成"using 字段名"即可。


聯(lián)合查詢:

  • 聯(lián)合查詢是將多個(gè)查詢結(jié)果在記錄上進(jìn)行拼接。(相當(dāng)于將其他表的查詢記錄結(jié)果連接到第一個(gè)表的后面)【因?yàn)槭瞧唇樱?strong>多個(gè)查詢結(jié)果的字段數(shù)必須相同】【拼接不在意數(shù)據(jù)類型,比如第一個(gè)表的第一個(gè)字段是int,但后面的表中的varchar依然可以拼接到第一列中】
  • 語法:select語句 union select語句…;
    select name,gender from student
    union 
    select * from class;
    -- 因?yàn)閏lass就兩個(gè)字段,所以第一個(gè)只選出兩個(gè)字段
    image

補(bǔ)充:

  • union可以有選項(xiàng),加在union 后面,all選項(xiàng)是不對(duì)相同去重,distinct是去重。
  • 聯(lián)合查詢一般用來處理同一表中以不同方法顯示不同數(shù)據(jù)。(比如,想將學(xué)生各科成績(jī)表中的兩科(這里假設(shè)為python 跟linux)同時(shí)查詢出來)
  • union和order by同時(shí)使用報(bào)錯(cuò)時(shí)
    • 如果你想針對(duì)聯(lián)合查詢中的某個(gè)查詢結(jié)果排序,需要將這個(gè)select語句用括號(hào)括起來?!玖硗猓捎诼?lián)合查詢的拼接機(jī)制,需要在order by 后面加上limit子句才行,limit的數(shù)量可以是一個(gè)很大的值。】
    • 如果是針對(duì)最終的聯(lián)合查詢結(jié)果,就在最后一個(gè)select語句中使用order by 【建議給最后一個(gè)字段加上括號(hào),再加ordery by,使用情況是有同名字段】


子查詢:

  • 子查詢是嵌套在查詢語句中的查詢。
  • 子查詢按照出現(xiàn)的位置可以分為三類:
    • from子查詢:子查詢跟在from之后的;一般用在“先查出二維表,再處理”的情況。
      • 比如:
        -- 這是一個(gè)無意義的例子。僅為舉例使用
        select cid,cname from (select * from class where cname="python") as c;
    • where子查詢:子查詢跟在where條件中;一般用在“先查詢出指定條件再查詢”的情況
      • 比如:
        select * from student where cid=(select cid from class where cname="python");
    • exist子查詢:子查詢?cè)趀xist語句里面;一般用作“存在才做”的情況
      • 比如:
        -- 這是一個(gè)如果學(xué)生沒有選擇cid=1的課,那么不輸出對(duì)應(yīng)課程信息的例子
        select * from class where exists(select * from student where cid=1) and cid=1;
    • 事實(shí)上,有些人認(rèn)為union之后跟著的也是子查詢,不過這里不把這些當(dāng)作子查詢,只把上面幾個(gè)與“查詢”非常緊密相關(guān)的當(dāng)作子查詢。

補(bǔ)充:

  • 事實(shí)上,還可以根據(jù)結(jié)果來分類子查詢:
    • 標(biāo)量子查詢,子查詢得到的結(jié)果是一行一列,情況一般發(fā)生于where子查詢只查詢出一行一列的情況。
    • 列子查詢,子查詢得到的結(jié)果是一列多行,情況一般發(fā)生于where子查詢查詢出一列多行的情況。
    • 行子查詢,子查詢得到的結(jié)果是多列一行(或者多行多列) ,情況一般發(fā)生在where子查詢查詢出多列一行的情況。
    • 表子查詢,子查詢得到的結(jié)果是多行多列 ,情況一般發(fā)生在from子查詢中
  • where子查詢中有時(shí)候還使用一些其他關(guān)鍵字,如any,all,some,但對(duì)=來說,=基本可以實(shí)現(xiàn)他們的功能了。

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過程技巧大全》、《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總

希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。

相關(guān)文章

  • mysql存儲(chǔ)過程之循環(huán)語句(WHILE,REPEAT和LOOP)用法分析

    mysql存儲(chǔ)過程之循環(huán)語句(WHILE,REPEAT和LOOP)用法分析

    這篇文章主要介紹了mysql存儲(chǔ)過程之循環(huán)語句(WHILE,REPEAT和LOOP)用法,結(jié)合實(shí)例形式分析了mysql存儲(chǔ)過程循環(huán)語句WHILE,REPEAT和LOOP的原理、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-12-12
  • Mysql中LAST_INSERT_ID()的函數(shù)使用詳解

    Mysql中LAST_INSERT_ID()的函數(shù)使用詳解

    從名字可以看出,LAST_INSERT_ID即為最后插入的ID值,有了這個(gè)實(shí)用的函數(shù),我們可以實(shí)現(xiàn)很多問題,下面我們就來深入探討下。
    2015-03-03
  • 規(guī)范化的SQL數(shù)據(jù)修改語句總結(jié)

    規(guī)范化的SQL數(shù)據(jù)修改語句總結(jié)

    本文將提供一些標(biāo)準(zhǔn)的SQL句,可供一些有需求的朋友參考
    2012-11-11
  • mysql 登錄時(shí)閃退的問題解決方法

    mysql 登錄時(shí)閃退的問題解決方法

    這篇文章主要介紹了mysql 登錄時(shí)閃退的問題解決方法的相關(guān)資料,mysql 出現(xiàn)閃退問題,很是棘手在做項(xiàng)目的時(shí)候,這里對(duì)解決這樣的問題提供了解決方案,需要的朋友可以參考下
    2016-11-11
  • mysql實(shí)現(xiàn)定時(shí)備份的詳細(xì)圖文教程

    mysql實(shí)現(xiàn)定時(shí)備份的詳細(xì)圖文教程

    這篇文章主要給大家介紹了關(guān)于mysql實(shí)現(xiàn)定時(shí)備份的詳細(xì)圖文教程,我們都知道數(shù)據(jù)是無價(jià),如果不對(duì)數(shù)據(jù)進(jìn)行備份,相當(dāng)是讓數(shù)據(jù)在裸跑,一旦服務(wù)器出問題,只有哭的份了,需要的朋友可以參考下
    2023-07-07
  • 安裝mysq 5.7.20 解壓版遇到的坑(推薦)

    安裝mysq 5.7.20 解壓版遇到的坑(推薦)

    最近有朋友說當(dāng)mysql5.7.20解壓版環(huán)境變量配置好后,根目錄沒有my.ini 也沒有 my-default.ini文件,怎么處理這個(gè)問題呢,下面小編給大家?guī)砹私鉀Q方案,大家可以參考下
    2017-11-11
  • 關(guān)于查詢MySQL字段注釋的5種方法總結(jié)

    關(guān)于查詢MySQL字段注釋的5種方法總結(jié)

    在MySQL數(shù)據(jù)庫(kù)中,字段或列的注釋是用屬性comment來添加,下面這篇文章主要給大家介紹了關(guān)于查詢MySQL字段注釋的5種方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01
  • MySQL8.0.24版本Release Note的一些改進(jìn)點(diǎn)

    MySQL8.0.24版本Release Note的一些改進(jìn)點(diǎn)

    這篇文章主要介紹了MySQL8.0.24版本Release Note的一些改進(jìn)點(diǎn),幫助大家更好的對(duì)新版本的MySQL進(jìn)行測(cè)試使用,感興趣的朋友可以了解下
    2021-04-04
  • Docker搭建MySQL并掛載數(shù)據(jù)的全過程

    Docker搭建MySQL并掛載數(shù)據(jù)的全過程

    環(huán)境搭建費(fèi)時(shí)費(fèi)力,但要必不可少,這篇文章主要給大家介紹了關(guān)于Docker搭建MySQL并掛載數(shù)據(jù)的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-01-01
  • MySQL系列理解運(yùn)用union(all)與limit及exists關(guān)鍵字教程

    MySQL系列理解運(yùn)用union(all)與limit及exists關(guān)鍵字教程

    這篇文章主要為大家介紹了MySQL系列中union(all)、limit及exists關(guān)鍵字的教程示例講解,通過本篇文章就可以理解MySQL中的這些關(guān)鍵字的概念以及實(shí)際的運(yùn)用
    2021-10-10

最新評(píng)論