技术文摘
SQL 查询文章列表并判断当前用户是否点赞的方法
2025-01-14 18:07:05 小编
在开发涉及文章展示与用户交互功能的应用时,经常需要实现查询文章列表并判断当前用户是否点赞的功能。这不仅能提升用户体验,还能增强平台的互动性。下面就为大家详细介绍如何使用 SQL 实现这一功能。
我们需要有两个关键的数据库表:文章表(articles)和点赞表(likes)。文章表用于存储文章的基本信息,例如文章 ID、标题、内容等;点赞表则用于记录用户对文章的点赞操作,包含点赞 ID、用户 ID 和文章 ID 等字段。
假设文章表的结构如下:
CREATE TABLE articles (
article_id INT PRIMARY KEY AUTO_INCREMENT,
title VARCHAR(255),
content TEXT
);
点赞表的结构如下:
CREATE TABLE likes (
like_id INT PRIMARY KEY AUTO_INCREMENT,
user_id INT,
article_id INT,
FOREIGN KEY (user_id) REFERENCES users(user_id),
FOREIGN KEY (article_id) REFERENCES articles(article_id)
);
接下来,要查询文章列表并判断当前用户是否点赞,可以使用如下的 SQL 查询语句:
SELECT
a.article_id,
a.title,
a.content,
CASE
WHEN l.user_id IS NOT NULL THEN 1
ELSE 0
END AS is_liked
FROM
articles a
LEFT JOIN
likes l ON a.article_id = l.article_id AND l.user_id = <current_user_id>;
在上述查询中,我们使用 LEFT JOIN 将文章表和点赞表进行关联。通过 a.article_id = l.article_id 确保关联的文章是正确的,并且通过 l.user_id = <current_user_id> 筛选出当前用户的点赞记录。CASE 语句用于判断当前用户是否对文章点赞,如果 l.user_id 不为空,则表示用户已经点赞,is_liked 字段为 1;否则为 0。
通过这种方式,我们可以一次性获取文章列表,并清楚地知道当前用户对每篇文章的点赞状态。在实际应用中,只需将 <current_user_id> 替换为当前登录用户的实际 ID 即可。这种 SQL 查询方法简洁高效,能够满足大多数场景下查询文章列表并判断用户点赞状态的需求,为开发人员提供了便利。
- 六年软件工程师生涯的五大惨痛教训
- createObjectURL API 好用至极,几个场景让您明白
- Rust 让 Python 函数速度飙升 5000%
- 以 C++ 视角揭开 2024 春晚魔术的神秘面纱!
- 处理上亿数据且内存限制 1G 时的去重方法
- C#中捕获类属性变化信息的方法
- 九款常见 JVM 垃圾回收器
- Python 初学者常遇的五个陷阱
- 面试官提问:线程池的工作原理是怎样的?
- IntelliJ IDEA 助力高效跨平台开发
- 15 款卓越的开源免费 Python 开发工具(IDE)
- 深度剖析 Sora 技术原理
- Python 中字符串转列表的常用手段
- RocketMQ 如此之快的十大源码揭秘
- JVM 类加载:类的初始化与类加载器双亲委托机制