亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請教各位一個問題,求解答:MySQL關于select id form table where id not in (1, 2, 3)的疑問

請教各位一個問題,求解答:MySQL關于select id form table where id not in (1, 2, 3)的疑問

DIEA 2019-08-21 12:02:16
因為業務需求,我需要做一個向推薦用戶視頻的功能要求是已經推薦過的視頻,下次不能重復推薦,我現在有2種做法第一種做法:每次用戶拉取推薦視頻列表時把視頻id都用Redis儲存起來比如拉取列表分頁的第一頁,共10個視頻,我會把第一頁的10個視頻id存起來,下次拉取推薦視頻列表時,我先從Redis中取出該用戶的瀏覽過的視頻id,然后用MySQL查詢出來:selectid,titleformvideo_tablewhereidnotin(1,2...1000)limit10;第二種做法:建立一張瀏覽記錄表user_browses,字段是user_id,video_id那么我每次向用戶推薦視頻時,就向這張表中插入瀏覽記錄,下次拉取視頻列表時,MySQL直接這樣查詢:selectid,titleformvideo_tablewhereidnotin(selectvideo_idfromuser_browseswhereuser_id=1)limit10;第一種做法是用Redis存用戶的瀏覽記錄,可以減輕MySQL寫入壓力,但是如果瀏覽記錄特別多,比如1000個id,那我執行的SQL語句就特別長,這個樣子會影響MySQL的查詢性能嗎?第二種做法SQL語句不會像一種做法那么長,缺點就是MySQL會多一點寫入壓力,而且查詢的時候用子查詢的方式,多查詢一次請問這兩種做法哪種更合適?
查看完整描述

2 回答

?
慕工程0101907

TA貢獻1887條經驗 獲得超5個贊

首先notin的效率非常低,不會走index,無論你這兩種做法都是要修改成notexist的
我的另外一種想法:
假設A用戶看過的視頻數量是N個,形成一個數組。從數據庫中selectidfromvideo_table的速度是非??斓?假設得到一個長M的數組。
你只要從M與N的差集中隨便選10個id取mysql查詢就可以了。
這樣mysql的壓力就會變得很小,壓力可以放到應用服務器上來。
                            
查看完整回答
反對 回復 2019-08-21
  • 2 回答
  • 0 關注
  • 405 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號