濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Mysql自連接查詢(xún)實(shí)例詳解

Mysql自連接查詢(xún)實(shí)例詳解

熱門(mén)標(biāo)簽:怎么在地圖標(biāo)注位置生成圖片 銅陵防封電銷(xiāo)卡 400電話(huà)可以免費(fèi)申請(qǐng)嗎 真人語(yǔ)音電話(huà)機(jī)器人 騰訊地圖標(biāo)注提升 電銷(xiāo)卡外呼系統(tǒng)供應(yīng)商 悟空科技電話(huà)機(jī)器人 美國(guó)反騷擾電話(huà)機(jī)器人 福建外呼系統(tǒng)定制化

本文實(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è)不同的別名,然后附上連接條件。看下面的例子:

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。

復(fù)制代碼 代碼如下:
select s.id, s.cate_name, p.cate_name from tdb_cates s left join tdb_cates p on s.parent_id=p.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。

復(fù)制代碼 代碼如下:
select s.id, s.cate_name, p.cate_name from tdb_cates s left join tdb_cates p on p.parent_id=s.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ì)有所幫助。

您可能感興趣的文章:
  • MySQL中基本的多表連接查詢(xún)教程
  • php基礎(chǔ)之連接mysql數(shù)據(jù)庫(kù)和查詢(xún)數(shù)據(jù)
  • 詳解MySQL中的分組查詢(xún)與連接查詢(xún)語(yǔ)句
  • mysql連接查詢(xún)(左連接,右連接,內(nèi)連接)
  • MySQL優(yōu)化之使用連接(join)代替子查詢(xún)
  • MySQL筆記之連接查詢(xún)?cè)斀?/li>
  • mysql多表連接查詢(xún)實(shí)例講解
  • 你知道哪幾種MYSQL的連接查詢(xún)

標(biāo)簽:臨汾 烏海 聊城 云浮 湖南 湖北 武威 白銀

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql自連接查詢(xún)實(shí)例詳解》,本文關(guān)鍵詞  Mysql,自,連接,查詢(xún),實(shí)例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mysql自連接查詢(xún)實(shí)例詳解》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Mysql自連接查詢(xún)實(shí)例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    高陵县| 靖西县| 都兰县| 当涂县| 蒲江县| 银川市| 会东县| 岑巩县| 九龙坡区| 仁化县| 新平| 威海市| 内丘县| 漳浦县| 甘南县| 上杭县| 孝感市| 屯昌县| 大厂| 泸西县| 枣强县| 集贤县| 凉山| 阜平县| 福清市| 新密市| 老河口市| 博罗县| 望城县| 桓仁| 余庆县| 专栏| 隆回县| 东海县| 孟村| 邵东县| 尼勒克县| 昌邑市| 临邑县| 海丰县| 大田县|