Mysql自連接查詢實例詳解
本文實例講述了Mysql自連接查詢。分享給大家供大家參考,具體如下:
自連接查詢
假想以下場景:某一電商網(wǎng)站想要對站內(nèi)產(chǎn)品做層級分類,一個類別下面有若干子類,子類下面也會有別的子類。例如數(shù)碼產(chǎn)品這個類別下面有筆記本,臺式機(jī),智能手機(jī)等;筆記本,臺式機(jī),智能手機(jī)又可以按照品牌分類;品牌又可以按照價格分類,等等。也許這些分類會達(dá)到一個很深的層次,呈現(xiàn)一種樹狀的結(jié)構(gòu)。那么這些數(shù)據(jù)要怎么在數(shù)據(jù)庫中表示呢?我們可以在數(shù)據(jù)庫中創(chuàng)建兩個字段來存儲id和類別名稱,使用第三個字段存儲類別的子類或者父類的id,最后通過自連接去查詢想要的結(jié)果。
自連接查詢其實等同于連接查詢,需要兩張表,只不過它的左表(父表)和右表(子表)都是自己。做自連接查詢的時候,是自己和自己連接,分別給父表和子表取兩個不同的別名,然后附上連接條件??聪旅娴睦樱?/p>
1. 創(chuàng)建數(shù)據(jù)表:
create table tdb_cates( id smallint primary key auto_increment, cate_name varchar(20) not null, parent_id smallint not null );
注:cate_name表示分類的名稱,parent_id表示父類的id。
2. 插入數(shù)據(jù):
insert into tdb_cates(cate_name, parent_id) values('數(shù)碼產(chǎn)品', 0);
insert into tdb_cates(cate_name, parent_id) values('家用產(chǎn)品', 0);
insert into tdb_cates(cate_name, parent_id) values('筆記本', 1);
insert into tdb_cates(cate_name, parent_id) values('智能手機(jī)', 1);
insert into tdb_cates(cate_name, parent_id) values('電器', 2);
insert into tdb_cates(cate_name, parent_id) values('家具', 2);
insert into tdb_cates(cate_name, parent_id) values('冰箱', 5);
insert into tdb_cates(cate_name, parent_id) values('洗衣機(jī)', 5);
insert into tdb_cates(cate_name, parent_id) values('汽車品牌', 0);
insert into tdb_cates(cate_name, parent_id) values('別克', 9);
insert into tdb_cates(cate_name, parent_id) values('寶馬', 9);
insert into tdb_cates(cate_name, parent_id) values('雪佛蘭', 9);
insert into tdb_cates(cate_name, parent_id) values('家紡', 0);
查詢結(jié)果:

3. 查詢所有分類以及分類的父類:假想有左右兩張表(都是tdb_cates),左表是子表,右表是父表;查詢子表的id,子表的cate_name,父表的cate_name;連接條件是子表的parent_id等于父表的id。
查詢結(jié)果:

4. 查詢所有分類以及分類的子類:還是假想有左右兩張表(都是tdb_cates),左表是子表,右表是父表;查詢子表的id,子表的cate_name,父表的cate_name;連接條件是子表的id等于父表的parent_id。
查詢結(jié)果:

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。
相關(guān)文章
MySQL中datetime和timestamp的區(qū)別及使用詳解
這篇文章主要介紹了MySQL中datetime和timestamp的區(qū)別及使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
MySQL?中如何歸檔數(shù)據(jù)的實現(xiàn)方法
本文主要介紹了MySQL?中如何歸檔數(shù)據(jù)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
大數(shù)據(jù)小內(nèi)存排序問題如何巧妙解決
文章介紹了大數(shù)據(jù)小內(nèi)存排序的三種方法:數(shù)據(jù)庫排序、分治法和位圖法,數(shù)據(jù)庫排序簡單但速度慢,對設(shè)備要求高;分治法高效但實現(xiàn)復(fù)雜;位圖法可讀性差,但存儲空間受限2025-01-01
MySQL數(shù)據(jù)庫Shell import_table數(shù)據(jù)導(dǎo)入
本文我們介紹一款高效的數(shù)據(jù)導(dǎo)入工具,MySQL Shell 工具集中的import_table,該工具的全稱是Parallel Table Import Utility,需要的朋友請參考下文2021-08-08
深入研究mysql中的varchar和limit(容易被忽略的知識)
這篇文章主要介紹了深入研究mysql中的varchar和limit(容易被忽略的知識),本文探究了varchar(5)可以存儲多少個漢字、多少個字母數(shù)字和mysql中的limit你真的會用嗎兩個知識點,需要的朋友可以參考下2015-03-03

