Flask之自定义模型类

4.3自定义模型类

定义模型

模型表示程序使用的数据实体,在Flask-SQLAlchemy中,模型一般是Python类,继承自db.Model,db是SQLAlchemy类的实例,代表程序使用的数据库。

类中的属性对应数据库表中的列。id为主键,是由Flask-SQLAlchemy管理。db.Column类构造函数的第一个参数是数据库列和模型属性类型。

如下示例:定义了两个模型类,作者和书名。

#coding=utf-8
from flask import Flask,render_template,redirect,url_for
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)

#设置连接数据
app.config[‘SQLALCHEMY_DATABASE_URI‘] = ‘mysql://root:[email protected]:3306/test1‘

#设置每次请求结束后会自动提交数据库中的改动
app.config[‘SQLALCHEMY_COMMIT_ON_TEARDOWN‘] = True
#设置成 True,SQLAlchemy 将会追踪对象的修改并且发送信号。这需要额外的内存, 如果不必要的可以禁用它。
app.config[‘SQLALCHEMY_TRACK_MODIFICATIONS‘] = True

#实例化SQLAlchemy对象
db = SQLAlchemy(app)

#定义模型类-作者
class Author(db.Model):
    __tablename__ = ‘author‘
    id = db.Column(db.Integer,primary_key=True)
    name = db.Column(db.String(32),unique=True)
    email = db.Column(db.String(64))
    au_book = db.relationship(‘Book‘,backref=‘author‘)
    def __str__(self):
        return ‘Author:%s‘ %self.name

#定义模型类-书名
class Book(db.Model):
    __tablename__ = ‘books‘
    id = db.Column(db.Integer,primary_key=True)
    info = db.Column(db.String(32),unique=True)
    leader = db.Column(db.String(32))
    au_book = db.Column(db.Integer,db.ForeignKey(‘author.id‘))
    def __str__(self):
        return ‘Book:%s,%s‘%(self.info,self.lead)

创建表 db.create_all()

查看author表结构 desc author

查看books表结构 desc books

#coding=utf-8
from flask import Flask,render_template,url_for,redirect,request
from flask_sqlalchemy import SQLAlchemy
from flask_wtf import FlaskForm
from wtforms.validators import DataRequired
from wtforms import StringField,SubmitField

app = Flask(__name__)

app.config[‘SQLALCHEMY_DATABASE_URI‘] = ‘mysql://root:[email protected]/test1‘
app.config[‘SQLALCHEMY_COMMIT_ON_TEARDOWN‘] = True
app.config[‘SQLALCHEMY_TRACK_MODIFICATIONS‘] = True
app.config[‘SECRET_KEY‘]=‘s‘

db = SQLAlchemy(app)

#创建表单类,用来添加信息
class Append(Form):
    au_info = StringField(validators=[DataRequired()])
    bk_info = StringField(validators=[DataRequired()])
    submit = SubmitField(u‘添加‘)

@app.route(‘/‘,methods=[‘GET‘,‘POST‘])
def index():
    #查询所有作者和书名信息
    author = Author.query.all()
    book = Book.query.all()
    #创建表单对象
    form = Append()
    if form.validate_on_submit():
        #获取表单输入数据
        wtf_au = form.au_info.data
        wtf_bk = form.bk_info.data
        #把表单数据存入模型类
        db_au = Author(name=wtf_au)
        db_bk = Book(info=wtf_bk)
        #提交会话
        db.session.add_all([db_au,db_bk])
        db.session.commit()
        #添加数据后,再次查询所有作者和书名信息
        author = Author.query.all()
        book = Book.query.all()
        return render_template(‘index.html‘,author=author,book=book,form=form)
    else:
        if request.method==‘GET‘:
            render_template(‘index.html‘, author=author, book=book,form=form)
    return render_template(‘index.html‘,author=author,book=book,form=form)

#删除作者
@app.route(‘/delete_author<id>‘)
def delete_author(id):
    #精确查询需要删除的作者id
    au = Author.query.filter_by(id=id).first()
    db.session.delete(au)
    #直接重定向到index视图函数
    return redirect(url_for(‘index‘))

#删除书名
@app.route(‘/delete_book<id>‘)
def delete_book(id):
    #精确查询需要删除的书名id
    bk = Book.query.filter_by(id=id).first()
    db.session.delete(bk)
    #直接重定向到index视图函数
    return redirect(url_for(‘index‘))

if __name__ == ‘__main__‘:
    db.drop_all()
    db.create_all()
    #生成数据
    au_xi = Author(name=‘我吃西红柿‘,email=‘[email protected]‘)
    au_qian = Author(name=‘萧潜‘,email=‘[email protected]‘)
    au_san = Author(name=‘唐家三少‘,email=‘[email protected]‘)
    bk_xi = Book(info=‘吞噬星空‘,lead=‘罗峰‘)
    bk_xi2 = Book(info=‘寸芒‘,lead=‘李杨‘)
    bk_qian = Book(info=‘飘渺之旅‘,lead=‘李强‘)
    bk_san = Book(info=‘冰火魔厨‘,lead=‘融念冰‘)
    #把数据提交给用户会话
    db.session.add_all([au_xi,au_qian,au_san,bk_xi,bk_xi2,bk_qian,bk_san])
    #提交会话
    db.session.commit()
    app.run(debug=True)

生成数据后,查看数据:

模板页面示例:

   <h1>玄幻系列</h1>
    <form method="post">
        {{ form.csrf_token }}
        <p>作者:{{ form.au_info }}</p>
        <p>书名:{{ form.bk_info }}</p>
        <p>{{ form.submit }}</p>
    </form>
    <ul>
        <li>{% for x in author %}</li>
        <li>{{ x }}</li><a href=‘/delete_author{{ x.id }}‘>删除</a>
        <li>{% endfor %}</li>
    </ul>
    <hr>
    <ul>
        <li>{% for x in book %}</li>
        <li>{{ x }}</li><a href=‘/delete_book{{ x.id }}‘>删除</a>
        <li>{% endfor %}</li>
    </ul>

添加数据后,查看数据:

原文地址:https://www.cnblogs.com/alexzhang92/p/9552708.html

时间: 2024-08-29 07:37:36

Flask之自定义模型类的相关文章

第五十八课、自定义模型类(上)------------------狄泰软件学院

 一.自定义模型类 1.QStandardItemModel是一个通用的模型类 (1).能够以任意的方式组织数据(线程.非线性) (2).数据组织的基本单位为数据项(QStandardItem) (3).每一个数据项能够存储多个具体数据(附加数据角色) (4).每一个数据项能够对数据状态进行控制(可编辑.可选...) 2.Qt中的通用模型类QStandardItemModel (1).QStandardItemModel继承自抽象的模型类QAbstractItemModel (2).QStand

第60课 自定义模型类(下)

1. 界面GUI设计 2. 界面的类图设计 3. 右键上下文菜单的实现 (1)定义菜单对象(QMenu) (2)连接菜单中QAction对象到槽函数 (3)定义事件过滤器,并处理ContextMenu事件 (4)在当前鼠标的位置打开菜单对象 [编程实验]数据应用界面和右键菜单的实现 //main.cpp #include "Widget.h" #include <QApplication> int main(int argc, char *argv[]) { QApplic

第58课 自定义模型类(上)

1. QStandardItemModel是一个通用的模型类 (1)能够以任意的方式组织数据(线性.非线性) (2)数据组织的基本单位为数据项(QStandardItem) (3)每一个数据项能够存储多个具体数据(可通过附加数据角色加以区别) (4)每一个数据项能够对数据状态进行控制(可编辑.可选.--) 2. Qt中的通用模型类:QStandartItemModel (1)QStandardItemModel继承自QAbstractItemModel. (2)QStandardItemMode

Flask中定义模型类的几种情况

from datetime import datetime from werkzeug.security import generate_password_hash, check_password_hash from utils import constants from . import db class BaseModel(object): """模型基类,为每个模型补充创建时间与更新时间""" create_time = db.Column

第59课 自定义模型类(中)

1. 系统架构图(续上节的实例分析) 2. 类的设计与实现 (1)DataSource类的设计与实例 ①设置数据源并读取数据 ②对数据进行解析后生成数据对象 (2)ScoreInfo类的设计与实现 ①封装数据源中的一组完整数据(即一条记录信息) ②提供返回具体数据值的接口函数 (3)ScoreInfoModel类的设计与实现 ①使用标准模型类QStandardItemModel作为成员(这里采用组合方式,而不采用继承) ②以ScoreInfo类对象为最小单位进行数据组织 3. 数据交互流程图 [

自定义MVC框架之工具类-模型类

截止目前已经改造了5个类: ubuntu:通过封装验证码类库一步步安装php的gd扩展 自定义MVC框架之工具类-分页类的封装 自定义MVC框架之工具类-文件上传类 自定义MVC框架之工具类-图像处理类 这个模型类支持以下功能: >连贯操作,js叫链式操作,连贯操作的函数可以打乱顺序,最后一个函数必须是执行语句的那个函数,如select, delete, update, add等 如 $db->table( 'user' )->where( 'id=1' )->select() 等

Flask框架之多对多关系模型类的定义

案例代码: table_relation = db.Table('stu_tea_rel', # 关系表明 db.Column('stu_id', db.Integer, db.ForeignKey('student.id')), # 多关系表的主键 db.Column('tea_id', db.Integer, db.ForeignKey('teacher.id'))) # 多关系表的主键 class Student(db.Model): id = db.Column(db.Integer,

qt model/view 架构自定义模型之QStringListModel

# -*- coding: utf-8 -*- # python:2.x #QStringListModel #QStringListModel 是最简单的模型类,具备向视图提供字符串数据的能力. #QStringListModel 是一个可编辑的模型,可以为组件提供一系列字符串作为数据. #看作是封装了 QStringList 的模型.QStringList 是一种很常用的数据类型,实际上 #是一个字符串列表(也就是 QList<QString>).既然是列表,它也就是线性的数据结构, #因

django的模型类管理器-----------数据库操作的封装

模型实例方法 str():在将对象转换成字符串时会被调用. save():将模型对象保存到数据表中,ORM框架会转换成对应的insert或update语句. delete():将模型对象从数据表中删除,ORM框架会转换成对应的delete语句. 模型类的属性 属性objects:管理器,是Manager类型的对象,用于与数据库进行交互. 当没有为模型类定义管理器时,Django会为模型类生成一个名为objects的管理器,自定义管理器后,Django不再生成默认管理器objects. 管理器是D