技术文摘
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 查询方法简洁高效,能够满足大多数场景下查询文章列表并判断用户点赞状态的需求,为开发人员提供了便利。
- Node.js 中 SO_RESUEPORT 的使用
- IaC 的 9 大益处与 4 大工具
- 2021 年 jQuery 处于何种状态?
- 基于 CRDT 的数据最终一致性实现
- CSS 进阶:熟悉却陌生的 Content
- 前端百题斩:从渲染流程解析重绘与回流
- Synchronized 已用 仍存线程安全问题
- WebStorm:合理使用这一好用的 Git 工具
- 我在大厂面试中收获的 C# 知识
- 巧用适配器模式,工作量减半不是梦
- 如何获取结构体成员的反射信息?
- 25 个 Vue 技巧:开发 5 年才知晓的独特用法
- 12306 自动抢票攻略
- Flutter 与 React Native:谁更适配送餐应用开发
- 深度剖析无锁编程