当前位置: 首页 > news >正文

篇章二 论坛系统——系统设计

目录

2.系统设计

2.1 技术选型

2.2 设计数据库结构

2.2.1 数据库实体

1. 数据库设计

1.1 数据库名: forum db

1.2 表的设计

1.3 编写SQL


2.系统设计

2.1 技术选型

2.2 设计数据库结构

2.2.1 数据库实体

通过需求分析获得概念类并结合业务实现过程中的技术需要,设计出数据库实体

1. 数据库设计

运用分析模型章节中定义概念类的方法,能过观察现在的论坛并结合具体业务需要完成类的定义

1.1 数据库名: forum db

公共字段:无特殊要求的情况下,每张表必须有长整型的自增主键,除状态、创建时间、更新时间,如下所示:

1.2 表的设计

1.确定论坛中的类 对应到数据库中的表

 

2.为类确定属性

 

(1)用户类

 加密 解密

(2)板块

(3)帖子

 

(4)帖子的回复

 

(5)站内信

 

1.3 编写SQL

(1)确定MYSQL版本

SELECT VERSION(); 

(2)创建数据库

# 创建数据库
DROP DATABASE IF EXISTS forum_db;
CREATE DATABASE forum_db CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

(3)创建数据表

 

# 选择数据库
USE forum_db# 创建表# 用户表
DROP TABLE IF EXISTS t_user;
CREATE TABLE t_user(id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '编号,主键自增',username VARCHAR(20) NOT NULL UNIQUE COMMENT '用户名,唯一',PASSWORD VARCHAR(32) NOT NULL COMMENT '加密后的密码',nickname VARCHAR(50) NOT NULL COMMENT '昵称',phoneNum VARCHAR(20) COMMENT '手机号',email VARCHAR(50) COMMENT '电子邮箱',gender TINYINT NOT NULL DEFAULT 2 COMMENT '性别 0女, 1男, 2保密',salt VARCHAR(32) NOT NULL COMMENT '为密码加盐',avatarUrl VARCHAR(255) COMMENT '用户头像路径',articleCount INT NOT NULL DEFAULT 0 COMMENT '发帖数量',isAdmin TINYINT NOT NULL DEFAULT 0 COMMENT '是否管理员 0否, 1是',remark VARCHAR(1000) COMMENT '备注, 自我介绍',state TINYINT NOT NULL DEFAULT 0 COMMENT '状态 0正常, 1禁言',deleteState TINYINT NOT NULL DEFAULT 0 COMMENT '是否删除 0否, 1是',createTime DATETIME NOT NULL COMMENT '创建时间,精确到秒',updateTime DATETIME NOT NULL COMMENT '更新时间,精确到秒'
);# 板块表
DROP TABLE IF EXISTS t_board;
CREATE TABLE t_board(id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '编号,主键自增',	NAME VARCHAR(50) NOT NULL COMMENT '板块名',articleCount INT NOT NULL DEFAULT 0 COMMENT '帖子数量',sort INT NOT NULL DEFAULT 0 COMMENT '排序优先级, 升序',state TINYINT NOT NULL DEFAULT 0 COMMENT '状态 0正常, 1禁用',deleteState TINYINT NOT NULL DEFAULT 0 COMMENT '是否删除 0否, 1是',createTime DATETIME NOT NULL COMMENT '创建时间,精确到秒',updateTime DATETIME NOT NULL COMMENT '更新时间,精确到秒'
);# 帖子表
DROP TABLE IF EXISTS t_article;
CREATE TABLE t_article(id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '编号,主键自增',	boardId BIGINT NOT NULL COMMENT '关联板块编号',userId BIGINT NOT NULL COMMENT '发帖人,关联用户编号',title VARCHAR(100) NOT NULL COMMENT '帖子标题',content TEXT NOT NULL COMMENT '帖子正文',visitCount INT NOT NULL DEFAULT 0 COMMENT '访问量',replyCount INT NOT NULL DEFAULT 0 COMMENT '回复数',likeCount INT NOT NULL DEFAULT 0 COMMENT '点赞数',state TINYINT NOT NULL DEFAULT 0 COMMENT '状态 0正常, 1禁用',deleteState TINYINT NOT NULL DEFAULT 0 COMMENT '是否删除 0否, 1是',createTime DATETIME NOT NULL COMMENT '创建时间,精确到秒',updateTime DATETIME NOT NULL COMMENT '更新时间,精确到秒'
);# 帖子回复表
DROP TABLE IF EXISTS t_article_reply;
CREATE TABLE t_article_reply(id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '编号,主键自增',	articleId BIGINT NOT NULL COMMENT '关联帖子编号',postUserId BIGINT NOT NULL COMMENT '楼主用户, 关联用户编号',replyId BIGINT NOT NULL COMMENT '关联回复编号, 支持楼中楼',replyUserId BIGINT NOT NULL COMMENT '楼主下的回复用户编号, 支持楼中楼',content VARCHAR(500) NOT NULL COMMENT '回帖内容',likeCount INT NOT NULL COMMENT '回帖内容', state TINYINT NOT NULL DEFAULT 0 COMMENT '状态 0正常, 1禁用',deleteState TINYINT NOT NULL DEFAULT 0 COMMENT '是否删除 0否, 1是',createTime DATETIME NOT NULL COMMENT '创建时间,精确到秒',updateTime DATETIME NOT NULL COMMENT '更新时间,精确到秒'
);# 站内信表
DROP TABLE IF EXISTS t_message;
CREATE TABLE t_message(id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '编号,主键自增',	postUserId BIGINT NOT NULL COMMENT '发送者, 关联用户编号',receiveUserId BIGINT NOT NULL COMMENT '接收者, 关联用户编号',content VARCHAR(255) NOT NULL COMMENT '内容',state TINYINT NOT NULL DEFAULT 0 COMMENT '状态 0正常, 1禁用',deleteState TINYINT NOT NULL DEFAULT 0 COMMENT '是否删除 0否, 1是',createTime DATETIME NOT NULL COMMENT '创建时间,精确到秒',updateTime DATETIME NOT NULL COMMENT '更新时间,精确到秒'
);

 

http://www.xdnf.cn/news/949681.html

相关文章:

  • C/C++ 面试复习笔记(5)
  • nuclio的配置文件yaml和docker compose的yaml的区别
  • 依赖注入(Dependency Injection)
  • 关于YOLOV5—Mosaic数据增强
  • 电源滤波器:不起眼却如何保障电子设备电源?
  • 1091 Acute Stroke (30)
  • 2025年全国I卷数学压轴题解答
  • 大模型链路调试平台之LangSmith实战指南
  • Web 架构之 API 安全防护:防刷、防爬、防泄漏
  • SpringBoot整合SSM
  • React中子传父组件通信操作指南
  • 使用VBA嵌套字典快速转换BOM表格
  • 鸢尾花分类(KNN)
  • 【AI News | 20250609】每日AI进展
  • 测试微信模版消息推送
  • 开源:FTP同步工具
  • 【粤语克隆】粤语声音,一秒克隆:如何用AI为岭南文化按下快进键
  • composer init
  • LeetCode - 647. 回文子串
  • 具身智能之人形机器人核心零部件介绍
  • 教程:PyCharm 中搭建多级隔离的 Poetry 环境(从 Anaconda 到项目专属.venv)
  • 重启Eureka集群中的节点,对已经注册的服务有什么影响
  • 深入理解JavaScript设计模式之单例模式
  • AirPosture | 通过 AirPods 矫正坐姿
  • 安科瑞户储ADL200N-CT:即插即用破解家庭光伏安装困局
  • HBase学习:通俗易懂的实例解析
  • K8S认证|CKS题库+答案| 10. Trivy 扫描镜像安全漏洞
  • Java中HashMap底层原理深度解析:从数据结构到红黑树优化
  • 人工智能 - 在Dify、Coze、n8n、FastGPT和RAGFlow之间做出技术选型
  • Excel处理控件Aspose.Cells教程:在Excel 文件中创建、操作和渲染时间线