-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdata_base_init.py
38 lines (29 loc) · 1.65 KB
/
data_base_init.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
from flask import Flask, request, render_template, jsonify, Blueprint
import json # Python標準のJSONライブラリを読み込んで、データの保存等に使用する
import datetime
from flask_sqlalchemy import SQLAlchemy
from flask_startup import app
app.config["JSON_AS_ASCII"] = False # 日本語などのASCII以外の文字列を返したい場合は、こちらを設定しておく
# データベース
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///example.db'
db = SQLAlchemy(app)
class Data(db.Model):
id = db.Column(db.String(50), primary_key=True) # 課題識別用のID
title = db.Column(db.String(120))
deadline = db.Column(db.DateTime)
subject = db.Column(db.String(120))
star_num = db.Column(db.Integer)
memo = db.Column(db.String(2000))
memo_img = db.Column(db.String(120)) # メモの画像のファイル名をuuidで保存
created_by = db.Column(db.String(120))
created_at = db.Column(db.DateTime,
default=datetime.datetime.now(datetime.timezone(datetime.timedelta(hours=9)))) # 作成日時(日本時間)
updated_at = db.Column(db.DateTime, default=datetime.datetime.now(datetime.timezone(datetime.timedelta(hours=9))),
onupdate=datetime.datetime.now(datetime.timezone(datetime.timedelta(hours=9)))) # 更新日時(日本時間)
if __name__ == "__main__":
# debugモードが不要の場合は、debug=Trueを消してください
# app.run(debug=True)
with app.app_context():
db.drop_all() # データベースの全てのテーブルを削除
db.create_all() # データベースのテーブルを再作成
pass