效果图
模型设计
class User(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(20))
username = db.Column(db.String(20)) # 用户名
password_hash = db.Column(db.String(128)) # 密码散列值
activities = db.relationship('Activity', secondary='activity_user', backref='users', lazy='dynamic')
def set_password(self, password): # 用来设置密码的方法,接受密码作为参数
self.password_hash = generate_password_hash(password) # 将生成的密码保持到对应字段
def validate_password(self, password): # 用于验证密码的方法,接受密码作为参数
return check_password_hash(self.password_hash, password) # 返回布尔值
class Admin(db.Model, UserMixin):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(20))
username = db.Column(db.String(20))
password_hash = db.Column(db.String(128))
def set_password(self, password):
self.password_hash = generate_password_hash(password)
def validate_password(self, password):
return check_password_hash(self.password_hash, password)
class Activity(db.Model):
id = db.Column(db.Integer, primary_key=True)
activity_name = db.Column(db.String(64))
activity_info = db.Column(db.String(512))
price = db.Column(db.Integer) # 票价
limit = db.Column(db.Integer) # 限制人数
applied = db.Column(db.Integer, default=0) # 购买已通过人数
time = db.Column(db.DateTime) # 举办时间
deadline = db.Column(db.Date) # 购买截止时间
location = db.Column(db.String(64)) # 位置
lon = db.Column(db.Float) # 经度
lat = db.Column(db.Float) # 纬度
activity_user = db.Table('activity_user',
db.Column('activity_id', db.Integer, db.ForeignKey('activity.id'),primary_key=True),
db.Column('user_id', db.Integer, db.ForeignKey('user.id'),primary_key=True),
)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/63006.html