Flask和Django中自定义模型类的表名、父类问题

                    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中,均有框架已封装好的模型类,而且固定了自定义的模型类必须继承自框架已封装好的模型类作为其父类.

你可能感兴趣的:(Flask和Django中自定义模型类的表名、父类问题)