首頁  >  文章  >  後端開發  >  分錶之後,依照時間排序取得資料有沒有好的方式

分錶之後,依照時間排序取得資料有沒有好的方式

WBOY
WBOY原創
2016-08-10 09:07:191614瀏覽

有三張表:

用戶表: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...

應該按照你查詢條件進行分錶,不然沒有好辦法

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn