个人博客开发之数据库设计

kenx
• 阅读 1801

前言

分享完需求,我们就按照需求去设计数据库就可以了,这里我数据库选用 Mysql 原因呢Mysql相对于其他数据库如ORACLE轻巧,方便,开源,免费,好用,而且效率也够用

数据库设计

这里数据库设计我推荐大家一款数据库设计工具,我一直在使用觉得还不错叫PDMan

个人博客开发之数据库设计

个人博客开发之数据库设计

个人博客开发之数据库设计

多平台版本,Mac Windows,Linux 系统都有 。总之功能非常强大 ,PDMan官网

分表设计

用户表

CREATE TABLE users(
    user_Id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '用户ID' ,
    user_name VARCHAR(128)    COMMENT '用户名' ,
    user_nickname VARCHAR(128)    COMMENT '用户昵称' ,
    pwd VARCHAR(64)    COMMENT '用户密码' ,
    email VARCHAR(64)    COMMENT '用户邮箱' ,
    avatar VARCHAR(128)    COMMENT '用户头像' ,
    create_time DATETIME    COMMENT '注册时间' ,
    birthday DATE    COMMENT '用户生日' ,
    age INT    COMMENT '用户年龄' ,
    moble_phone VARCHAR(32)    COMMENT '用户手机号' ,
    PRIMARY KEY (user_Id)
) COMMENT = '用户 ';;

个人博客开发之数据库设计

文章表

CREATE TABLE article(
    article_id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '博文ID' ,
    push_data DATETIME    COMMENT '发布日期' ,
    article_user VARCHAR(32)    COMMENT '发表用户' ,
    title VARCHAR(1024)    COMMENT '博文标题' ,
    like_count INT    COMMENT '点赞数' ,
    comment_count INT    COMMENT '评论数' ,
    read_count INT    COMMENT '浏览量' ,
    top_flag VARCHAR(1)    COMMENT '是否置顶' ,
    create_time DATETIME    COMMENT '创建时间' ,
    article_summary VARCHAR(1024)    COMMENT '文章摘要' ,
    PRIMARY KEY (article_id)
) COMMENT = '文章 ';;

个人博客开发之数据库设计

文章详情

CREATE TABLE article_detail(
    article_detail_id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '文章详情id' ,
    content_md TEXT    COMMENT '文章markdown内容' ,
    content_html TEXT    COMMENT '文章html内容' ,
    article_id BIGINT    COMMENT '文章id' ,
    PRIMARY KEY (article_detail_id)
) COMMENT = '文章详情 ';;

个人博客开发之数据库设计

文章标签

CREATE TABLE article_tag_referenced(
    atr_Id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '引用id' ,
    article_id BIGINT    COMMENT '文章id' ,
    tag_id BIGINT    COMMENT '标签id' ,
    PRIMARY KEY (atr_Id)
) COMMENT = '文章标签 ';;

个人博客开发之数据库设计

文章分类

CREATE TABLE article_category_referenced(
    acr_id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '引用id' ,
    article_id BIGINT    COMMENT '文章id' ,
    category_id BIGINT    COMMENT '类目id' ,
    PRIMARY KEY (acr_id)
) COMMENT = '文章分类 ';;

个人博客开发之数据库设计

分类表

CREATE TABLE category(
    category_id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '分类ID' ,
    category_name VARCHAR(64)    COMMENT '分类名称' ,
    alias_name VARCHAR(64)    COMMENT '分类别名' ,
    description VARCHAR(128)    COMMENT '分类描述' ,
    parennt_id BIGINT    COMMENT '父分类ID' ,
    create_time DATETIME    COMMENT '创建时间' ,
    PRIMARY KEY (category_id)
) COMMENT = '分类 ';;

个人博客开发之数据库设计

标签表

CREATE TABLE tag(
    tag_id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '标签ID' ,
    tag_name VARCHAR(64)    COMMENT '标签名称' ,
    alias_name VARCHAR(64)    COMMENT '标签别名' ,
    description VARCHAR(128)    COMMENT '标签描述' ,
    create_time DATETIME    COMMENT '创建时间' ,
    PRIMARY KEY (tag_id)
) COMMENT = '标签 ';;

个人博客开发之数据库设计

评论表

CREATE TABLE discuss(
    discuss_id BIGINT NOT NULL AUTO_INCREMENT  COMMENT '评论ID' ,
    create_time DATETIME    COMMENT '评论日期' ,
    like_count INT    COMMENT '点赞数' ,
    discuss_user BIGINT    COMMENT '发表用户' ,
    article_id BIGINT    COMMENT '评论文章ID' ,
    content VARCHAR(3072)    COMMENT '评论内容' ,
    parent_id BIGINT    COMMENT '父评论ID' ,
    PRIMARY KEY (discuss_id)
) COMMENT = '评论 ';;

个人博客开发之数据库设计

关注公众号猿小叔获取更多干货分享

个人博客开发之数据库设计

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Easter79 Easter79
3年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
皕杰报表(关于日期时间时分秒显示不出来)
在使用皕杰报表设计器时,数据据里面是日期型,但当你web预览时候,发现有日期时间类型的数据时分秒显示不出来,只有年月日能显示出来,时分秒显示为0:00:00。1.可以使用tochar解决,数据集用selecttochar(flowdate,"yyyyMMddHH:mm:ss")fromtablename2.也可以把数据库日期类型date改成timestamp
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
00_设计模式之语言选择
设计模式之语言选择设计模式简介背景设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结。设计模式(Designpattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
美凌格栋栋酱 美凌格栋栋酱
38分钟前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(