亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

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

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

PHP
HUX布斯 2022-07-16 10:17:22
我在下面設計了多對多表:activity----------idnameactivity_student----------idactivity_idstudent_idstudent----------idname每個學生可以參加很多活動,每個活動可以有很多參與者。我想從活動中選擇,同時我想將參與者收集為數組。我想要制作的最終數據如下:[  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 語句檢索了學生的數據。但我認為這不是最佳實踐,因為查詢時間超過 10 秒,超過 10,000 行。最佳做法是什么?我正在使用 CI4,帶有 InnoDB 引擎的 mysql 數據庫。
查看完整描述

1 回答

?
FFIVE

TA貢獻1797條經驗 獲得超6個贊

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


閱讀有關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 ...

您會得到一個類似表格的結構,其中包含 ActivityName、StudentName 等。在其中WHERE您可以過濾到一個活動或其他任何內容。


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


查看完整回答
反對 回復 2022-07-16
  • 1 回答
  • 0 關注
  • 90 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號