mysql - 大部分?jǐn)?shù)據(jù)沒有行溢出的text字段是否需要拆表
問題描述
比如一個論壇系統(tǒng)的回帖表,多數(shù)情況下這個回帖的內(nèi)容都是簡短的,只有少部分內(nèi)容長。
而在顯示中這個內(nèi)容字段是常用的,還有必要把這個內(nèi)容字段單獨拆出來嗎?
<?phpnamespace KooguaModelEntity;class Reply extends EntityBase{ const STATUS_PENDING = 1; // 待定 const STATUS_APPROVED = 2; // 審?fù)? const STATUS_REJECTED = 3; // 審拒 const STATUS_DELETED = 4; // 刪除 /** * 主鍵編號 * @var integer */ public $id;/** * 回復(fù)內(nèi)容 * @var string */ public $content;/** * 提及用戶 * @var string */ public $mentions;/** * 用戶編號 * @var integer */ public $userId;/** * 主題編號 * @var integer */ public $topicId;/** * 版塊編號 * @var integer */ public $forumId;/** * 置頂標(biāo)識 * @var integer */ public $sticked;/** * 狀態(tài)標(biāo)識 * @var integer */ public $status;/** * 評論計數(shù) * @var integer */ public $commentCount;/** * 關(guān)注計數(shù) * @var integer */ public $watchCount;/** * 收藏計數(shù) * @var integer */ public $favoriteCount;/** * 贊同計數(shù) * @var integer */ public $agreeCount; /** * 反對計數(shù) * @var integer */ public $opposeCount;/** * 舉報計數(shù) * @var integer */ public $reportCount;/** * 創(chuàng)建時間 * @var integer */ public $createTime; /** * 更新時間 * @var integer */ public $updateTime; public function getSource() {return ’Reply’; } public function beforeCreate() {$this->createTime = time(); } }
問題解答
回答1:個人感覺沒必要,從語義上來講內(nèi)容屬于回帖表比較關(guān)鍵的數(shù)據(jù),另外分出來的話,每次需要連表查或者分兩次差太麻煩(而且這種基礎(chǔ)數(shù)據(jù),幾乎是100%需要的,如果是額外信息到可以考慮放出來)。
另外如果表太大的話,可以考慮分庫分表。
回答2:你可以先把你的表結(jié)構(gòu),粘貼出來。研究研究,我們在討論討論
回答3:規(guī)定回帖字?jǐn)?shù),沒有必要拆表。
相關(guān)文章:
1. html5 - css3scale和rotate同時使用轉(zhuǎn)換成matrix寫法該如何轉(zhuǎn)換?2. win10 python3.5 matplotlib使用報錯3. php多任務(wù)倒計時求助4. css - 如何把一個視圖放在左浮動定位的視圖的上面?5. javascript - jquery怎么讓a標(biāo)簽跳轉(zhuǎn)后保持tab的樣式6. MySQL的聯(lián)合查詢[union]有什么實際的用處7. javascript - 小demo:請教怎么做出類似于水滴不斷擴(kuò)張的效果?8. javascript - vue組件的重復(fù)調(diào)用9. python的正則怎么同時匹配兩個不同結(jié)果?10. javascript - axios請求回來的數(shù)據(jù)組件無法進(jìn)行綁定渲染
