分錶之後,依照時間排序取得資料有沒有好的方式
Aug 10, 2016 am 09:07 AM
有三張表:
用戶表:user-------------------user_id
文章表:article----------------article_id,user_id;
評論表:article_comment----comment_id,article_id
user表對article_comment表是一對多對多的關係。
現在對article_comment進行分錶,按照article_id%6分為article_comment_0/1/2/3/4/5六張表,
現在需要根據評論的時間來展示某一個用戶的所有文章的評論,sql該怎麼寫呢?
回覆內容:
有三張表:
用戶表:user-------------------user_id
文章表:article----------------article_id,user_id;
評論表:article_comment----comment_id,article_id
user表對article_comment表是一對多對多的關係。
現在對article_comment進行分錶,按照article_id%6分為article_comment_0/1/2/3/4/5六張表,
現在需要根據評論的時間來展示某一個用戶的所有文章的評論,sql該怎麼寫呢?
<code>SELECT * FROM((SELECT * FROM article_comment_0 INNER JOIN article ON article_comment_0.article_id=article.article_id WHERE article.user_id='userid') UNION (SELECT * FROM article_comment_1 INNER JOIN article ON article_comment_1.article_id=article.article_id WHERE article.user_id='userid') UNION (SELECT * FROM article_comment_2 INNER JOIN article ON article_comment_2.article_id=article.article_id WHERE article.user_id='userid') UNION (SELECT * FROM article_comment_3 INNER JOIN article ON article_comment_3.article_id=article.article_id WHERE article.user_id='userid') UNION (SELECT * FROM article_comment_4 INNER JOIN article ON article_comment_4.article_id=article.article_id WHERE article.user_id='userid') UNION (SELECT * FROM article_comment_5 INNER JOIN article ON article_comment_5.article_id=article.article_id WHERE article.user_id='userid')) res ORDER BY res.comment_createtime DESC </code>
你的表這樣子設計就要每次都去聯結article查詢,所以建議在common表中冗餘一個user_id字段,這樣查詢就不用多一步操作
能不分錶就不分錶,分錶會給開發帶來很大麻煩,你可以用分區,mysql不太懂,但是我搜到這個:
http://dev.mysql.com/doc/refm...
應該按照你查詢條件進行分錶,不然沒有好辦法

熱門文章

熱門文章

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發
