博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
模型分离(选做)
阅读量:5902 次
发布时间:2019-06-19

本文共 2051 字,大约阅读时间需要 6 分钟。

models.py

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

from datetime import datetimefrom werkzeug.security import generate_password_hash,check_password_hash
from exts import db
class User(db.Model):    __tablename__ = 'user'    id = db.Column(db.Integer, primary_key=TabError, autoincrement=True)    username = db.Column(db.String(20), nullable=False)    _password = db.Column(db.String(200), nullable=False) #neibushiyong    nickname = db.Column(db.String(20))    @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 resultclass Question(db.Model):    __tablename__ = 'question'    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)    creat_time = db.Column(db.DateTime, default=datetime.now)    author_id = db.Column(db.Integer, db.ForeignKey('user.id'))    author = db.relationship('User', backref=db.backref('question'))class Comment(db.Model):    __tablename__='comment'    id = db.Column(db.Integer, primary_key=True, autoincrement=True)    author_id = db.Column(db.Integer, db.ForeignKey('user.id'))    question_id = db.Column(db.Integer , db.ForeignKey('question.id'))    creat_time = db.Column(db.DateTime,default=datetime.now)    detail = db.Column(db.Text , nullable=False)    question = db.relationship('Question',backref = db.backref('comments',order_by=creat_time.desc))    author = db.relationship('User',backref = db.backref('comments'))

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

from flask_sqlalchemy import SQLAlchemydb = SQLAlchemy()

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

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

from models import Question,User,Commentfrom exts import dbapp=Flask(__name__)app.config.from_object(config)db.init_app(app)

转载于:https://www.cnblogs.com/Sun584125503/p/8116516.html

你可能感兴趣的文章
第四十八讲:tapestry 与 淘宝kissy editor编辑器带图片上传
查看>>
Linux/Centos 重置Mysql root用户密码
查看>>
[C语言]unicode与utf-8编码转换(一)
查看>>
利用PDO导入导出数据库
查看>>
DDR3
查看>>
分支 统计字数
查看>>
艾级计算机的发展与挑战
查看>>
RocketMQ事务消息实战
查看>>
mysql-mmm-2.2.1安装手册
查看>>
搭建yum源服务器
查看>>
delphi使用ado导出excel
查看>>
linux 命令详解 二十三
查看>>
IT职场人生系列之二:大学生活
查看>>
手把手教你做出好看的文本输入框
查看>>
zabbix 3.2.7 (源码包)安装部署
查看>>
vsCode 快捷键、插件
查看>>
vue-validator(vue验证器)
查看>>
jQuery Ajax MVC 下拉框联动
查看>>
html
查看>>
c#创建文件夹
查看>>