use mydb2
--1:用户表,存储博主和评论者信息
create table users(
id int primary key auto_increment comment '用户ID,主键',
username varchar(50) not null unique comment '用户名,唯一',
email varchar(100) not null unique comment '邮箱,唯一',
password_hash varchar(225) not null comment '加密后的密码',
avatar_url varchar(255) default '' comment '头像图片链接',
created_at TIMESTAMP default CURRENT_TIMESTAMP comment '创建时间'
)comment '用户表'
--2:文章表,存储博客文章
create table posts(
id int primary key auto_increment comment '文章ID,主键',
user_id int not null comment '作者ID,关联users.id',
title varchar(200) not null comment '文章标题',
content TEXT not null comment '文章正文',
summary varchar(500) comment '文章摘要',
view_count int default 0 comment '阅读数',
status ENUM('draft','published') default 'draft' comment '状态:草稿,已发布',
created_at TIMESTAMP default current_timestamp comment '创建时间',
updated_at TIMESTAMP default current_timestamp on update current_timestamp comment '最后更新时间',
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE ---键约束:用户删除则文章级联删除
) comment '文章表'
--3:评论表:存储对文章的评论
create table comments(
id int primary key auto_increment comment '评论ID,主键',
post_id int not null comment '所属文章ID,关联posts.id',
user_id int not null comment '评论者ID,关联users.id',
content TEXT not null comment '评论内容',
parent_id int default null comment '父评论ID(用于回复功能),自关联',
created_at TIMESTAMP default current_TIMESTAMP COMMENT '创建时间',
foreign key(user_id) references posts(id) on delete caseade, -- 文章删除则评论级联删除
foreign key(user_id) references users(id) on delete caseade -- 用户删除则评论级联删除
)comment '评论表'
-- 1. 插入模拟数据
INSERT INTO users (username, email, password_hash) VALUES
('小明', 'xiaoming@example.com', 'hash_of_password_123'),
('技术博主', 'tech@example.com', 'hash_of_password_456');
INSERT INTO posts (user_id, title, content, status) VALUES
(1, '我的第一篇博客', '今天天气真好,我开始写博客了...', 'published'),
(2, 'MySQL入门指南', '关系型数据库是Web开发的基石...', 'published'),
(2, '未完成的草稿', '这是一个还在构思中的文章...', 'draft');
INSERT INTO comments (post_id, user_id, content) VALUES
(1, 2, '欢迎加入博客圈!'),
(2, 1, '写得非常清晰,对我帮助很大!'),
(2, 2, '谢谢支持,欢迎持续关注。');
---基础查询练习
--查询所有已经发布的文章(按发布时间倒序)
select * from posts where status = 'published' order by created_at desc
MYSQL开发- (1)
m0_598177232026-01-08 8:24
相关推荐
雨中飘荡的记忆2 小时前
ElasticJob分布式调度从入门到实战冬奇Lab5 小时前
Android触摸事件分发、手势识别与输入优化实战城东米粉儿8 小时前
Android MediaPlayer 笔记Jony_8 小时前
Android 启动优化方案阿巴斯甜8 小时前
Android studio 报错:Cause: error=86, Bad CPU type in executable张小潇8 小时前
AOSP15 Input专题InputReader源码分析考虑考虑11 小时前
JDK25模块导入声明_小马快跑_12 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?_小马快跑_12 小时前
Kotlin | 协程调度器选择:何时用CoroutineScope配置,何时用launch指定?_小马快跑_12 小时前
Kotlin | 从SparseArray、ArrayMap的set操作符看类型检查的不同