第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會有你想問的

從多對多表中選擇所有數(shù)據(jù)的最有效方法是什么?

從多對多表中選擇所有數(shù)據(jù)的最有效方法是什么?

PHP
HUX布斯 2022-07-16 10:17:22
我在下面設(shè)計(jì)了多對多表:activity----------idnameactivity_student----------idactivity_idstudent_idstudent----------idname每個(gè)學(xué)生可以參加很多活動,每個(gè)活動可以有很多參與者。我想從活動中選擇,同時(shí)我想將參與者收集為數(shù)組。我想要制作的最終數(shù)據(jù)如下:[  id => 1,  name => football club activity,  participants =>    [      [        id => 1,        name => example student,        class => 3      ],      [        id => 3,        name => example student2,        class => 5      ]    ]]我嘗試為 student_id 選擇 activity.* 和 group_concat。然后我使用 foreach 語句檢索了學(xué)生的數(shù)據(jù)。但我認(rèn)為這不是最佳實(shí)踐,因?yàn)椴樵儠r(shí)間超過 10 秒,超過 10,000 行。最佳做法是什么?我正在使用 CI4,帶有 InnoDB 引擎的 mysql 數(shù)據(jù)庫。
查看完整描述

1 回答

?
FFIVE

TA貢獻(xiàn)1797條經(jīng)驗(yàn) 獲得超6個(gè)贊

在 SQL 中執(zhí)行復(fù)雜的任務(wù)幾乎總是比將大量數(shù)據(jù)拖回客戶端然后處理數(shù)據(jù)更有效。特別是在您要來回訪問數(shù)據(jù)庫的情況下。


閱讀有關(guān)JOIN.


SELECT  a.name AS ActivityName,

        s.name AS StudentName,

        ...

    FROM activity AS a

    JOIN activity_student AS map  USING(activity_id)

    JOIN student AS s  USING(student_id)

    WHERE ...

您會得到一個(gè)類似表格的結(jié)構(gòu),其中包含 ActivityName、StudentName 等。在其中WHERE您可以過濾到一個(gè)活動或其他任何內(nèi)容。


關(guān)于映射的有效模式的提示:http: //mysql.rjweb.org/doc.php/index_cookbook_mysql#many_to_many_mapping_table


查看完整回答
反對 回復(fù) 2022-07-16
  • 1 回答
  • 0 關(guān)注
  • 100 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號