Skip to content

数据表

在创建数据模型之前,先创建一个模型基类,封装一些通用的方法。

python
from forum.extensions import db


class BaseORM(db.Model):
    __abstract__ = True

    def save(self):
        db.session.add(self)
        db.session.commit()

    def delete(self):
        db.session.delete(self)
        db.session.commit()

    def as_json(self):
        return {c.name: getattr(self, c.name) for c in self.__table__.columns}

as_json 方法会将模型对象的所有字段转换为字典,方便序列化。

用户

User 类表示用户模型,用户模型包含存储用户信息和博客资料的字段:

  • 主键字段:id
  • 用户姓名:nick_name
  • 密码散列值:password_hash
  • 手机号:mobile
  • 用户头像路径:avatar_url
  • 最后一次登录时间:最后一次登录时间
  • 是否是管理员:is_admin
  • 用户签名:signature
  • 用户性别:gender

这些字段我们会在后面使用到的时候具体介绍。

python
from datetime import datetime

import sqlalchemy as sa

from forum.orms._base import BaseORM


class UserORM(BaseORM):
    """用户"""

    __tablename__ = "forum_user"

    id = sa.Column(sa.Integer, primary_key=True, comment="用户编号")
    nickname = sa.Column(sa.String(32), unique=True, nullable=False, comment="用户昵称")
    password_hash = sa.Column(sa.String(255), nullable=False, comment="加密的密码")
    mobile = sa.Column(sa.String(11), unique=True, nullable=False, comment="手机号")
    email = sa.Column(sa.String(50), comment="用户头像路径")
    avatar_url = sa.Column(sa.String(256), comment="用户头像路径")
    is_admin = sa.Column(sa.Boolean, default=False, comment="是否是管理员")
    signature = sa.Column(sa.String(512), comment="用户签名")

    gender = sa.Column(sa.Enum("男", "女"), default="男", comment="性别")

    create_at = sa.Column(sa.DateTime, default=datetime.utcnow, comment="创建时间")
    update_at = sa.Column(
        sa.DateTime,
        default=datetime.utcnow,
        onupdate=datetime.utcnow,
        comment="记录的更新时间",
    )

分类

用于存储文章分类的数据库模型

python
from datetime import datetime

import sqlalchemy as sa

from forum.orms._base import BaseORM


class CategoryORM(BaseORM):
    """文章分类"""

    __tablename__ = "forum_category"

    id = sa.Column(sa.Integer, primary_key=True, comment="分类编号")
    name = sa.Column(sa.String(64), nullable=False, comment="分类名")

    create_at = sa.Column(sa.DateTime, default=datetime.utcnow, comment="创建时间")
    update_at = sa.Column(
        sa.DateTime,
        default=datetime.utcnow,
        onupdate=datetime.utcnow,
        comment="记录的更新时间",
    )

分类的名称不允许重复,因此 name 字段将 unique 参数设为 True。

文章

存储文章 Post 模型

python
from datetime import datetime

import sqlalchemy as sa

from forum.orms._base import BaseORM


class ArticleORM(BaseORM):
    """文章"""

    __tablename__ = "forum_article"

    id = sa.Column(sa.Integer, primary_key=True, comment="文章编号")
    title = sa.Column(sa.String(256), nullable=False, comment="文章标题")
    source = sa.Column(sa.String(64), nullable=False, comment="文章来源")
    digest = sa.Column(sa.String(512), nullable=False, comment="文章摘要")
    content = sa.Column(sa.Text, nullable=False, comment="文章内容")
    clicks = sa.Column(sa.Integer, default=0, comment="浏览量")
    index_image_url = sa.Column(sa.String(256), comment="文章列表图片路径")
    status = sa.Column(
        sa.Integer, default=0, comment="文章状态 如果为 0 代表审核通过,1 代表审核中,-1 代表审核不通过"
    )
    reason = sa.Column(sa.String(256), comment="未通过原因,status = -1 的时候使用")

    category_id = sa.Column(sa.Integer, sa.ForeignKey("forum_category.id"))
    user_id = sa.Column(sa.Integer, sa.ForeignKey("forum_user.id"))

    create_at = sa.Column(sa.DateTime, default=datetime.utcnow, comment="创建时间")
    update_at = sa.Column(
        sa.DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, comment="更新时间"
    )

评论

用来存储评论的模型类 Comment

python
from datetime import datetime

import sqlalchemy as sa

from forum.orms._base import BaseORM


class CommentORM(BaseORM):
    """评论"""

    __tablename__ = "forum_comment"

    id = sa.Column(sa.Integer, primary_key=True, comment="评论编号")
    content = sa.Column(sa.Text, nullable=False, comment="评论内容")
    parent_id = sa.Column(
        sa.Integer, sa.ForeignKey("forum_comment.id"), comment="父评论id"
    )
    like_count = sa.Column(sa.Integer, default=0, comment="点赞条数")
    user_id = sa.Column(sa.Integer, sa.ForeignKey("forum_user.id"), comment="用户id")
    article_id = sa.Column(sa.Integer, sa.ForeignKey("forum_article.id"), comment="文章id")

    create_at = sa.Column(sa.DateTime, default=datetime.utcnow, comment="创建时间")
    update_at = sa.Column(
        sa.DateTime, default=datetime.utcnow, onupdate=datetime.utcnow, comment="更新时间"
    )

最后将所有的模型导入到 __init__.py

python
from .article import ArticleORM
from .category import CategoryORM
from .comment import CommentORM
from user import UserORM

__all__ = [ArticleORM, CategoryORM, CommentORM, UserORM]