mysql 查詢所有評論以及回復
問題描述
表設計如下
question(id, user_id,content)answer (id,question_id,user_id,content)reply (id,answer_id, user_id,content)
請問要怎么一次性查詢所有的評論和回復啊目前用group by和group_concat實現不了額..
問題解答
回答1:我理解:question是問題表,羅列所有的提問answer 是回復表,對某個具體問題的回復,用question_id與question表中的id做關聯reply 是對某個回復的評論,用answer_id與answer表中的id做關聯以下代碼,基于以上理解
select t1.q_id as 問題id, t1.q_user_id as 提問者id, t1.q_content as 問題內容, t2.a_id as 回復id, t2.a_user_id as 回復者id, t2.a_content as 回復內容, t3.r_id as 評論id, t3.r_user_id as 評論者id, t3.r_content as 評論內容from (select id as q_id ,user_id as q_user_id ,content as q_contentfrom question) t1 -- 所有的問題列表,用id做唯一性的區分left outer join(select id as a_id ,question_id ,user_id as a_user_id ,content as a_contentfrom answer) t2on t1.q_id = t2.question_id -- 每個question_id對應的回復left outer join(select id as r_id ,answer_id ,user_id as r_user_id ,content as r_content) t3 on t2.a_id = t3.answer_id -- 每個answer_id對應的評論回答2:
select reply.,answer.,question.* fromreply right join answer onreply.answer_id = answer.I’dright join question onanswer.question_id = question.idWhere question.id =(查找的question.id)
相關文章:
1. java - Spring MVC怎么實現提交表單后跳轉?2. 對mysql某個字段監控的功能3. javascript - windows下如何使用babel,遇到了困惑4. javascript - js中向下取整5. html - vue項目中用到了elementUI問題6. JavaScript事件7. showpassword里的this 是什么意思?代表哪個元素8. java - input file類型上傳了一個文件,想計算一下上傳文件的大小?9. javascript - table列過多,有什么插件可以提供列排序和選擇顯示列的功能10. python - 為什么正常輸出中文沒有亂碼,zip函數之后出現中文編程unicode編碼的問題,我是遍歷輸出的啊。
