-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodels.py
46 lines (38 loc) · 1.8 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
"""
This file defines the structure of table in the database, using ORM.
"""
from exts import db
from datetime import datetime
# Define the User class, which is used to store user information
class User(db.Model):
__tablename__ = 'user'
uid = db.Column(db.Integer, primary_key=True, autoincrement=True)
usermail = db.Column(db.String(100), nullable=False, unique=True)
password = db.Column(db.String(200), nullable=False)
# Define the Module class, which is used to store the modules of the user
class Class(db.Model):
__tablename__ = 'class'
cid = db.Column(db.Integer, primary_key=True, autoincrement=True)
cname = db.Column(db.String(50), nullable=False)
color = db.Column(db.String(50), nullable=False)
uid = db.Column(db.Integer, db.ForeignKey('user.uid'), nullable=False)
# Define the Task class, which is used to store tasks
class Task(db.Model):
__tablename__ = 'task'
tid = db.Column(db.Integer, primary_key=True, autoincrement=True)
task_name = db.Column(db.String(50), nullable=False)
task_description = db.Column(db.String(100), nullable=False)
task_status = db.Column(db.Boolean, nullable=False)
task_date = db.Column(db.Date)
task_time = db.Column(db.Time)
informed = db.Column(db.Boolean, nullable=False)
completed_date = db.Column(db.Date, nullable=True)
completed_time = db.Column(db.Time, nullable=True)
cid = db.Column(db.Integer, db.ForeignKey('class.cid'), nullable=False)
# Define the Captcha class, which is used to store the captcha
class Captcha(db.Model):
__tablename__ = 'captcha'
captcha_id = db.Column(db.Integer, primary_key=True, autoincrement=True)
usermail = db.Column(db.String(100), nullable=False)
captcha = db.Column(db.String(10), nullable=False)
create_time = db.Column(db.DateTime, nullable=False)