【Flask】世界杯购票网站开发

效果图
在这里插入图片描述

模型设计

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),
                         )
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个甜甜的大橙子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值