0

0

mysql实现简易博客系统的评论和用户数据库

P粉602998670

P粉602998670

发布时间:2026-01-07 00:51:17

|

612人浏览过

|

来源于php中文网

原创

users表需设username和email为UNIQUE,password_hash用VARCHAR(255)存哈希值;comments表通过外键关联users和posts,含parent_id支持嵌套,content用utf8mb4,查询用INNER JOIN连用户并按时间倒序。

mysql实现简易博客系统的评论和用户数据库

用户表设计要支持密码安全和唯一约束

用户注册登录必须保障基础安全,users 表不能只存明文密码。MySQL 本身不提供密码哈希函数(如 bcrypt),所以得靠应用层处理,但表结构要预留足够长度——VARCHAR(255) 是底线,因为 bcrypt 哈希值通常 60 字符左右,加盐后可能更长。

关键字段建议:

  • id:主键,INT UNSIGNED AUTO_INCREMENT
  • username:唯一且非空,加 UNIQUE 约束,避免重复注册
  • email:也建议加 UNIQUE,方便找回密码
  • password_hash:存哈希后的密码,**绝不能叫 password**,防止误读
  • created_at:用 TIMESTAMP DEFAULT CURRENT_TIMESTAMP 自动记录
CREATE TABLE users (
  id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
  username VARCHAR(50) NOT NULL UNIQUE,
  email VARCHAR(100) NOT NULL UNIQUE,
  password_hash VARCHAR(255) NOT NULL,
  created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

评论表必须关联用户和文章,并支持嵌套线索

简易博客的评论不需要无限级嵌套,但至少要能区分“谁在哪个文章下评了什么”。comments 表需外键指向 users 和文章表(假设叫 posts)。如果未来想支持“回复某条评论”,就加一个 parent_id 字段,允许为 NULL(表示一级评论)。

注意点:

I-Shop购物系统
I-Shop购物系统

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/

下载
  • 外键约束在 MySQL 中要求引擎为 InnoDB,MyISAM 不支持
  • content 字段别用 TEXT 就完事,要设字符集,比如 TEXT CHARACTER SET utf8mb4,否则 emoji 或生僻字会乱码
  • 不要用 DATETIME 存时间戳,用 TIMESTAMP 更省空间且自动时区转换友好
CREATE TABLE comments (
  id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
  user_id INT UNSIGNED NOT NULL,
  post_id INT UNSIGNED NOT NULL,
  parent_id INT UNSIGNED NULL,
  content TEXT CHARACTER SET utf8mb4 NOT NULL,
  created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
  FOREIGN KEY (post_id) REFERENCES posts(id) ON DELETE CASCADE
);

查询评论时要连表获取用户名,避免 N+1

展示评论列表时,前端需要显示“张三:今天天气不错”,而不是只显示 user_id = 5。一次查出所有数据比循环查用户更高效。用 JOIN 是标准做法,但要注意 LEFT JOIN 还是 INNER JOIN

  • INNER JOIN:只返回用户还存在、没被删的评论(推荐)
  • LEFT JOIN:即使用户被删,评论内容仍可见(需额外逻辑处理用户名显示)
  • 别漏掉 ORDER BY created_at DESC,否则新评论在最底下
SELECT c.id, u.username, c.content, c.created_at
FROM comments c
INNER JOIN users u ON c.user_id = u.id
WHERE c.post_id = 123
ORDER BY c.created_at DESC;

删除用户时外键级联要谨慎启用

ON DELETE CASCADE 看似省事,但一删用户,ta 所有评论全没了,连历史痕迹都不留。对博客系统来说,这往往不合适。更稳妥的做法是:

  • user_id 外键改成 ON DELETE SET NULL,但前提是该字段允许 NULL
  • 或干脆去掉级联,由应用层控制:删用户前先检查是否有评论,提示“请先转移或匿名化其评论”
  • 如果真要用 CASCADE,务必在删除前加事务和确认日志,比如:START TRANSACTION; DELETE FROM users WHERE id = 123; SELECT ROW_COUNT();

另外,posts 表若也参与级联(比如删文章连带删评论),那两个 CASCADE 链起来风险更大——删错一篇热门文章,几百条评论瞬间蒸发。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

657

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

244

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

252

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

526

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

596

2023.08.14

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.6万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 783人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号