推荐算法是会经常遇到的技术。主要解决的是问题是:如果你喜欢书 A,那么你可能会喜欢书 B。
本文我们使用 MySQL ,基于数据统计,拆解实现了一个简单的推荐算法。
首先,创建一个 用户喜欢的书数据表,所表示的是 user_id 喜欢 book_id。
CREATE TABLE user_likes (
user_id INT NOT NULL,
book_id VARCHAR(10) NOT NULL,
PRIMARY KEY (user_id,book_id),
UNIQUE KEY book_id (book_id, user_id)
);
CREATE TABLE user_likes_similar (
user_id INT NOT NULL,
liked_user_id INT NOT NULL,
rank INT NOT NULL,
KEY book_id (user_id, liked_user_id)
);
插入4条测试数据
INSERT INTO user_likes VALUES (1, 'A'), (1, 'B'), (1, 'C');
INSERT INTO user_likes VALUES (2, 'A'), (2, 'B'), (2, 'C'), (2,'D');
INSERT INTO user_likes VALUES (3, 'X'), (3, 'Y'), (3, 'C'), (3,'Z');
INSERT INTO user_likes VALUES (4, 'W'), (4, 'Q'), (4, 'C'), (4,'Z');
代表的含义为:用户 1 喜欢A、B