Mysql自連接查詢(xún)實(shí)例詳解
本文實(shí)例講述了Mysql自連接查詢(xún)。分享給大家供大家參考,具體如下:
自連接查詢(xún)
假想以下場(chǎng)景:某一電商網(wǎng)站想要對(duì)站內(nèi)產(chǎn)品做層級(jí)分類(lèi),一個(gè)類(lèi)別下面有若干子類(lèi),子類(lèi)下面也會(huì)有別的子類(lèi)。例如數(shù)碼產(chǎn)品這個(gè)類(lèi)別下面有筆記本,臺(tái)式機(jī),智能手機(jī)等;筆記本,臺(tái)式機(jī),智能手機(jī)又可以按照品牌分類(lèi);品牌又可以按照價(jià)格分類(lèi),等等。也許這些分類(lèi)會(huì)達(dá)到一個(gè)很深的層次,呈現(xiàn)一種樹(shù)狀的結(jié)構(gòu)。那么這些數(shù)據(jù)要怎么在數(shù)據(jù)庫(kù)中表示呢?我們可以在數(shù)據(jù)庫(kù)中創(chuàng)建兩個(gè)字段來(lái)存儲(chǔ)id和類(lèi)別名稱(chēng),使用第三個(gè)字段存儲(chǔ)類(lèi)別的子類(lèi)或者父類(lèi)的id,最后通過(guò)自連接去查詢(xún)想要的結(jié)果。
自連接查詢(xún)其實(shí)等同于連接查詢(xún),需要兩張表,只不過(guò)它的左表(父表)和右表(子表)都是自己。做自連接查詢(xún)的時(shí)候,是自己和自己連接,分別給父表和子表取兩個(gè)不同的別名,然后附上連接條件??聪旅娴睦樱?/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表示分類(lèi)的名稱(chēng),parent_id表示父類(lèi)的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('汽車(chē)品牌', 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);
查詢(xún)結(jié)果:
3. 查詢(xún)所有分類(lèi)以及分類(lèi)的父類(lèi):假想有左右兩張表(都是tdb_cates),左表是子表,右表是父表;查詢(xún)子表的id,子表的cate_name,父表的cate_name;連接條件是子表的parent_id等于父表的id。
查詢(xún)結(jié)果:
4. 查詢(xún)所有分類(lèi)以及分類(lèi)的子類(lèi):還是假想有左右兩張表(都是tdb_cates),左表是子表,右表是父表;查詢(xún)子表的id,子表的cate_name,父表的cate_name;連接條件是子表的id等于父表的parent_id。
查詢(xún)結(jié)果:
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《MySQL查詢(xún)技巧大全》、《MySQL常用函數(shù)大匯總》、《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過(guò)程技巧大全》及《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》
希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。
相關(guān)文章
mysql中insert ignore、insert和replace的區(qū)別及說(shuō)明
這篇文章主要介紹了mysql中insert ignore、insert和replace的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08MySQL 不允許從遠(yuǎn)程訪問(wèn)的解決方法
MySQL 不允許從遠(yuǎn)程訪問(wèn)的原因有很多除了下面的方法,還有需要看服務(wù)器安全設(shè)置禁止訪問(wèn)本機(jī)的3306端口。2010-03-03Mybatis動(dòng)態(tài)傳入order?by問(wèn)題
這篇文章主要介紹了Mybatis動(dòng)態(tài)傳入order?by問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12mysql中update按照多重條件進(jìn)行更新處理的方案
更新數(shù)據(jù)是使用數(shù)據(jù)庫(kù)時(shí)最重要的任務(wù)之一,下面這篇文章主要給大家介紹了關(guān)于mysql中update按照多重條件進(jìn)行更新處理的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09一次MySQL啟動(dòng)導(dǎo)致的事故實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了一次MySQL啟動(dòng)導(dǎo)致的事故實(shí)戰(zhàn)記錄,記錄了MySQL 啟動(dòng)成功但未監(jiān)聽(tīng)端口的解決方法,文中給出了詳細(xì)的解決方法,需要的朋友可以參考下2021-09-09SQL update多表關(guān)聯(lián)更新方法解讀
這篇文章主要介紹了SQL update 多表關(guān)聯(lián)更新方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Windows 64位重裝MySQL的教程(Zip版、解壓版MySQL安裝)
這篇文章主要介紹了Windows 64位,重裝MySQL的方法(Zip版、解壓版MySQL安裝),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值需要的朋友可以參考下2020-02-02