• 模型分离(选做)


    模型分离--让代码更方便管理

    新建models.py,将模型定义全部放到这个独立的文件中。

    from exts import db
    from werkzeug.security import generate_password_hash,check_password_hash
    from datetime import datetime
    
    
    # 创建用户模型
    class User(db.Model):
        __tablename__ = 'user'
        id = db.Column(db.Integer,primary_key=True,autoincrement=True)
        username = db.Column(db.String(20),nullable=False)
        _password = db.Column(db.String(200),nullable=False)#内部使用
        nickname=db.Column(db.String(50))
    
        @property
        def password(self): #外部使用
            return self._password
    
        @password.setter
        def password(self,row_password):
            self._password=generate_password_hash(row_password)
    
        def check_password(self,row_password):
            result=check_password_hash(self._password,row_password) #对比内部与外部存储的密码是否一样
            return result
    
    
    
    
    #创建发布问答模型
    class Question(db.Model):
        __tablename__ ='questions'
        id = db.Column(db.Integer, primary_key=True, autoincrement=True)
        title=db.Column(db.String(100),nullable=False)
        detail=db.Column(db.Text,nullable=False)
        create_time=db.Column(db.DateTime,default=datetime.now)
        author_id=db.Column(db.Integer,db.ForeignKey('user.id'))#外键约束,数据类型db.Integer第二个参数指定外键是user表的id
        author=db.relationship('User',backref=db.backref('questions'))
    
    # 创建评论模型
    class Comment(db.Model):
        __tablename__ = 'comments'
        id = db.Column(db.Integer, primary_key=True, autoincrement=True)
        author_id = db.Column(db.Integer, db.ForeignKey('user.id'))
        questions_id = db.Column(db.Integer, db.ForeignKey('questions.id'))
        create_time=db.Column(db.DateTime, default=datetime.now)
        detail=db.Column(db.Text,nullable=False)
        questions=db.relationship('Question',backref=db.backref('comments',order_by=create_time.desc))
        author=db.relationship('User',backref=db.backref('comments'))

    新建exts.py,将db = SQLAlchemy()的定义放到这个独立的文件中。

    from flask_sqlalchemy import SQLAlchemy
    
    db = SQLAlchemy()

    models.py和主py文件,都从exts.py中导入db。

    from exts import db

    在主py文件中,对db进行始化,db.init_app(app)。

    db.init_app(app)
  • 相关阅读:
    Angular Universal 学习笔记
    SAP Spartacus 如何获得当前渲染页面的 CMS 元数据
    Angular 服务器端渲染的学习笔记(二)
    Angular 服务器端渲染的学习笔记(一)
    第三方外部 Saas提供商如何跟使用 SAP 系统的客户进行对接接口集成
    如何从 SAP Spartacus Product Detail 页面,找到其 Angular 实现 Component 的位置
    具备自动刷新功能的 SAP ABAP ALV 报表
    C++学习目录
    c--条件编译
    c--文件读写--二进制
  • 原文地址:https://www.cnblogs.com/iamzhuangyuan/p/8117104.html
Copyright © 2020-2023  润新知