麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 網站 > 幫助中心 > 正文

擁有5星評級數據庫表結構 如何才能更高效的使用?

2024-07-09 22:47:52
字體:
來源:轉載
供稿:網友
產品數據庫設計時,經常遇到5星評價的情況,數據表如何設計才能即保證查詢效率,又能減少數據冗余呢?

初步設計思路如下,請大家指正。

一,最終效果,

二,表結構

復制代碼 代碼如下:

CREATE TABLE IF NOT EXISTS `books` (
  `id` int(8) NOT NULL auto_increment,
  `title` varchar(50) NOT NULL,
`vote_1` int(8) unsigned NOT NULL,
`vote_2` int(8) unsigned NOT NULL,
`vote_3` int(8) unsigned NOT NULL,
`vote_4` int(8) unsigned NOT NULL,
`vote_5` int(8) unsigned NOT NULL,
`avgrate` int(8) unsigned NOT NULL,
`AmountOfVotes` int(8) unsigned NOT NULL,
  PRIMARY KEY  (`id`)
) AUTO_INCREMENT=1 ;

CREATE TABLE IF NOT EXISTS `users` (
  `id` int(8) NOT NULL auto_increment,
  `username` varchar(20) NOT NULL,
  PRIMARY KEY  (`id`)
) AUTO_INCREMENT=1 ;

CREATE TABLE IF NOT EXISTS `votes` (
  `uid` int(8) unsigned NOT NULL,
  `bid` int(8) unsigned NOT NULL,
  `vote` int(1) NOT NULL,
  PRIMARY KEY (`bid`, `uid`)
) ;


三,設計思路

數據表分為兩個部分,

1,第一個部分,表votes。其中uid和bid設為了主鍵,這樣防止一個用戶多次投票的情況;

查詢時,可以使用,

復制代碼 代碼如下:

平均分:SELECT avg(vote) FROM votes WHERE bid = $bid;

評價總數: SELECT count(uid) FROM votes WHERE bid = $bid;


如果有時間排序的需求,可以再增加一個時間戳字段。

2,第二部分,冗余部分

vote_1到vote_5,僅記錄每一個級別評分的數量,有評分了則+1;

avgrate記錄平均分;
AmountOfVotes記錄總分;

其中avgrate和AmountOfVotes通過計算vote_1到vote_5得到,這樣減少了對表votes的大量查詢。

如果配合評論,那么評論中增加關聯即可,

復制代碼 代碼如下:


CREATE TABLE IF NOT EXISTS `comments` (
               `id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
               `rating_id` INT(11)  UNSIGNED NOT NULL DEFAULT 0,
               PRIMARY KEY ( `id` )
)


四,繼續優化需要思考的問題

votes表中的數據量會是book中數據量的N倍,這種設計也便于votes的分表,不影響快速查詢。

您可能感興趣的文章:

9個JavaScript評級/投票插件php+mysql結合Ajax實現點贊功能完整實例php+xml結合Ajax實現點贊功能完整實例jQuery簡單實現QQ空間點贊已經取消點贊基于UIControl控件實現ios點贊功能jQuery+Ajax+PHP“喜歡”評級功能實現代碼
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 精品一区二区三区免费毛片爱 | 黄在线免费看 | 欧美成人精品欧美一级乱黄 | 性少妇chinesevideo | 夜夜夜精品视频 | 毛片免费大全短视频 | www.91sese| 精品国产一区二区三区在线 | 91一区二区三区久久久久国产乱 | freexxxhd喷水| 久久亚洲线观看视频 | 精品一区二区三区免费看 | 精品一区二区三区中文字幕 | 99精品视频在线观看免费播放 | 欧美日韩精品一区二区三区不卡 | 国产无遮挡一区二区三区毛片日本 | 国产精品视频中文字幕 | 国产欧美精品综合一区 | 99精品在线视频观看 | 香蕉国产9| 亚洲99| 婷婷久久综合九色综合色多多蜜臀 | xvideos korean| 成年人福利视频 | 国产成人高潮免费观看精品 | 一区二区三区在线观看免费 | 7777奇米成人四色影视 | jj视频在线播放 | 中文字幕在线观看免费视频 | 成人在线视频在线观看 | 激情在线免费观看 | av免费在线播放网址 | 日韩欧美高清片 | 久久国产精 | 99影视电影电视剧在线播放 | av免费在线网| 蜜桃视频在线播放 | 亚州精品天堂中文字幕 | 日韩精品久久久 | 国产精品区一区二区三区 | 日本在线观看一区二区 |