-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodels.py
70 lines (55 loc) · 2.19 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
from db import db
from flask_login import UserMixin
from flask import json
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy.orm.attributes import QueryableAttribute
from werkzeug.security import generate_password_hash, check_password_hash
from sqlalchemy.sql import func
from datetime import datetime
# from flask import Flask
# app = Flask(__name__)
# app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///db/pkd.sqlite3'
# db = SQLAlchemy(app)
# 管理员用户表
class User(UserMixin,db.Model):
__tablename__ = 'users'
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(32), nullable=False)
password = db.Column(db.String(32), nullable=False)
def __init__(self, username, password):
self.username = username
self.set_password_hash(password)
def __repr__(self):
return '<User %r>' % (self.username)
def set_password_hash(self, password):
self.password = generate_password_hash(password)
def check_password(self, password):
return check_password_hash(self.password, password)
# 学生表
class Student(UserMixin,db.Model):
__tablename__ = 'students'
id = db.Column(db.Integer, primary_key=True,autoincrement=True)
name = db.Column(db.String(32), nullable=False)
password = db.Column(db.String(32), nullable=False)
age =db.Column(db.Integer)
funds = db.Column(db.Float)
addr = db.Column(db.String(32))
honor = db.Column(db.String(32))
def set_password_hash(self, password):
self.password = generate_password_hash(password)
def check_password(self, password):
return check_password_hash(self.password, password)
def __repr__(self):
return '<Student %r>' % (self.name)
# 优惠券表
class Key(db.Model):
__tablename__ = 'keys'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
code = db.Column(db.String(20), unique=True, nullable=False)
status = db.Column(db.Boolean,default=False) # 激活码是否被使用
createDt = db.Column(db.DateTime,default=datetime.now())
activeDt = db.Column(db.DateTime)
def __init__(self,code):
self.code = code
def __repr__(self):
return '<Keys %r>' % (self.name)