我在下面設計了多對多表: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
- 1 回答
- 0 關注
- 90 瀏覽
添加回答
舉報
0/150
提交
取消