脚本专栏 发布日期:2025/1/23 浏览次数:1
本文实例分析了Flask和Django框架中自定义模型类的表名、父类相关问题。分享给大家供大家参考,具体如下:
一. Flask和Django中定义表名(执行迁移后生成)的方式和flask是不同的:
1. Django中表名的定义方式,以代码为例说明
class User(AbstractUser): # 继承自认证系统模型类 """用户模型类""" mobile = modles.CharField(max_length=11, mix_length = 11, uniqe=True, verbose_name='手机号') class Meta: db_table = 'tb_users' # 定义数据库中表名 , 如果不定义Django会生成默认固定格式表名 verbose_name = 'tb_table' # 定义后台管理中类名 verbose_naem_plural = vervose_name # 定义后台管理中类
模型类中属性和修改类中verbose_name = ' ###'
均是用来在后台管理中显示的名称
2. Flask中表名的定义方式,以代码为例说明
from flask import Flask from flask_sqlalchemy import SQLAlchemy from settings import Config app = Flask(__name__) app.config.from_object(Config) db = SQLAlchemy(app) # 自定义模型类:一方 calss Movie(db.Model): # 必须继承自db.Model __tablename__ = 'movies' # 定义数据库中表名 id = db.Column(db.Integer,primary_key=True) name = db.Column(db.String(64),unique=True) # 一对多的关系模型中,一方定义关系,us给一方使用,实现一对多的查询,backref给多方使用,实现多对一的查询. us = db.relationship('Role', backref='movie') def __repr__(self): return 'Movie:%s' % self.name # 自定义模型类:多方 class Role(db.Model): __tablename__ = 'roles' # 如果不定义表名,flask会生成默认固定格式表名. id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(64), unique=True, index=True) email = db.Column(db.String(64),unique=True) password = db.Column(db.String(64)) movie_id = db.Column(db.Integer, db.ForeignKey('movie.id')) # 多方定义外键,指向一方主键 def __repr__(self): return 'Role:%s' % self.name if __name__ == '__main__': db.drop_all() db.cteate_all() app.run()
二. Flask和Django中父类问题
在Django和Flask中,均有框架已封装好的模型类,而且固定了自定义的模型类必须继承自框架已封装好的模型类作为其父类.
更多关于Python相关内容可查看本站专题:《Python入门与进阶经典教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。