因為業務需求,我需要做一個向推薦用戶視頻的功能要求是已經推薦過的視頻,下次不能重復推薦,我現在有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會多一點寫入壓力,而且查詢的時候用子查詢的方式,多查詢一次請問這兩種做法哪種更合適?
請教各位一個問題,求解答:MySQL關于select id form table where id not in (1, 2, 3)的疑問
DIEA
2019-08-21 12:02:16