-
Notifications
You must be signed in to change notification settings - Fork 137
/
Copy pathdb_sync.py
49 lines (39 loc) · 1.24 KB
/
db_sync.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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
Contact : [email protected]
Author : shenshuo
Date : 2018/12/24
Desc : 数据表生成
"""
import logging
from sqlalchemy import create_engine
from sqlalchemy.engine.url import URL
from websdk2.consts import const
from settings import settings as app_settings
from models.paas_model import Base as AppsBase
from models.authority import Base as AuBase
# ORM创建表结构
default_configs = app_settings[const.DB_CONFIG_ITEM][const.DEFAULT_DB_KEY]
url_object = URL.create(
drivername='mysql+pymysql',
username=default_configs.get(const.DBUSER_KEY),
password=default_configs.get(const.DBPWD_KEY),
host=default_configs.get(const.DBHOST_KEY),
port=int(default_configs.get(const.DBPORT_KEY)),
database=default_configs.get(const.DBNAME_KEY),
query={'charset': 'utf8mb4'}
)
engine = create_engine(url_object, echo=True)
def create():
try:
AuBase.metadata.create_all(engine)
AppsBase.metadata.create_all(engine)
logging.info('[Success] 表结构创建成功!')
except Exception as err:
logging.error(f'[Error] {err}!')
def drop():
AuBase.metadata.drop_all(engine)
AppsBase.metadata.drop_all(engine)
if __name__ == '__main__':
create()