-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathexample.py
51 lines (39 loc) · 1.52 KB
/
example.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
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_sqlalchemy_rest import Rest
import datetime
app = Flask(__name__)
app.config["SQLALCHEMY_DATABASE_URI"] = "sqlite:///example.sqlite"
# app.config["SQLALCHEMY_DATABASE_URI"] = "mysql://root:[email protected]/test"
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = True
app.config["SQLALCHEMY_ECHO"] = True
db = SQLAlchemy(app)
rest = Rest(app, db, max_page_size=300)
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(100), nullable=False)
age = db.Column(db.Integer)
key1 = db.Column(db.Float)
key2 = db.Column(db.Boolean, default=False)
key3 = db.Column(db.Text)
ctime1 = db.Column(db.DateTime, default=datetime.datetime.now)
ctime2 = db.Column(db.Date, default=datetime.datetime.now().date)
ctime3 = db.Column(db.Time, default=datetime.datetime.now().time)
class UserAddress(db.Model):
id = db.Column(db.Integer, primary_key=True)
user_id = db.Column(db.Integer)
address = db.Column(db.Text)
with app.app_context():
db.create_all()
user_join_models = {
'user_address': {
'model': UserAddress,
'column_a': User.id,
'column_b': UserAddress.user_id,
'inner_join': False,
}
}
rest.add_model(User, ignore_columns=['key1'], json_columns=['key3'], search_columns=['name', 'key3'], join_models=user_join_models)
rest.add_model(UserAddress)
if __name__=="__main__":
app.run(host="0.0.0.0",port=5050)