技术文摘
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 查询方法简洁高效,能够满足大多数场景下查询文章列表并判断用户点赞状态的需求,为开发人员提供了便利。
- 多列布局在现代CSS布局中是否仍有价值
- 怎样打造与 vue-element-admin 相媲美的清晰易懂文档
- 解决外边距与绝对定位冲突问题,详解CSS outline-offset属性
- typescript配置方法
- 不使用Flex或Grid实现HTML元素高度自适应的方法
- CSS实现带渐变色的镂空描边字体方法
- TypeScript 解析 JSON
- Antd Pagination分页组件首次加载样式异常问题的修复方法
- 配置TypeScript的tsc
- TypeScript类数据类型的声明
- TypeScript源码深度剖析
- LRU缓存数据结构:最近最少使用策略解析
- TypeScript基础数据类型
- TypeScript脚本编辑器
- TypeScript 基础学习