MySql連表之多對多

來源:互聯網
上載者:User

標籤:關係   ima   資料   pre   分析   blog   元素   mys   pen   

背景

每個男生和女生都可以選擇自己最喜歡的幾個人,可以是多個也可以使一個。

但是,在建立男生表的時候,女生表並沒存在,所以不能在創表初期就在男生表中加入其喜愛的女生名單,而且名字冗餘,儲存浪費空間。

設計表

1、表一:man

2、表二:woman

 

3、表三:man_to_woman

  1. 小趙<-->小花
  2. 小趙<-->小朵
  3. 小趙<-->小楠
  4. 小孫<-->小雨
  5. 小錢<-->小楠
  6. 小李<-->小花

建立外鍵

找到小趙喜歡的人

1 SELECT2     *3 FROM4     man_to_woman5 LEFT JOIN man ON man_to_woman.man_id = man.nid6 LEFT JOIN woman ON man_to_woman.woman_id = woman.nid7 WHERE8     man. NAME = "小趙"
Demo

分析SELECT * from man_to_woman LEFT JOIN man on man_to_woman.man_id = man.nid

從關係表中找到所有man中nid與關係表中的man.id相等的資料,將以man_to_woman為主,man只顯示與之向對應的內容,man為字典表。

分析LEFT JOIN woman on man_to_woman.woman_id = woman.nid

找到與上邊結果中的woman_id相等的woman表中nid的所有元素,以上表為主,woman為字典表。

分析where man.name = "小趙"

找到上邊中man的name為小趙的,成功找到他的3個心儀對象

MySql連表之多對多

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.