技术文摘
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 查询方法简洁高效,能够满足大多数场景下查询文章列表并判断用户点赞状态的需求,为开发人员提供了便利。
- 摆脱重复代码困扰,这套开源 SpringBoot 组件让效率猛增
- Java Lambda 表达式的多样用法,你是否掌握
- Java常见单元测试框架一览
- 几行代码实现 PPT 自动操作
- .NET 开发人员为何转向 Python
- Python 中 Self 关键字的从零解析
- Go 语言的自给自足:编译自身的奇妙征程
- Pulsar3.0 升级指南,你收获几何?
- 面试官竟称创建索引必锁表,是真的吗?
- Vue 2 最终版发布,版本号:Swan Song (绝唱)
- .NET Core 中出色日志框架的使用剖析及源代码展示
- Android 开发中常见的 Hook 技术盘点
- 10 分钟于 K8s 中部署当下最热门监控系统
- Redis Sentinel 监控与 Redis 节点故障自动恢复机制
- .Net 开发必知的泛型基础知识点汇总