有三張表:
用戶表: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...
應該按照你查詢條件進行分錶,不然沒有好辦法