-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcreation.py
executable file
·48 lines (37 loc) · 1.24 KB
/
creation.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
from app import db
from app import app
from app import modeles
from sqlalchemy import create_engine
import contextlib
import sqlalchemy.exc
import platform
import glob
# Création de la base de données
uri = app.config['SQLALCHEMY_DATABASE_URI'].split('/')
url = '/'.join(uri[:-1])
bd = uri[-1]
with contextlib.suppress(sqlalchemy.exc.ProgrammingError):
with create_engine(url, isolation_level='AUTOCOMMIT').connect() as conn:
conn.execute("CREATE DATABASE {} WITH encoding='utf-8'".format(bd))
print('Base de données créée.')
# Création des tables
db.session.execute("SET client_encoding='utf-8'")
db.session.execute('CREATE EXTENSION postgis')
db.session.commit()
db.create_all()
print('Tables créées.')
# Création des triggers
# Détection de l'OS
systeme = platform.system()
# Les slashs changent si on sur Windows
dossier = 'app\\triggers\*.sql' if systeme == 'Windows' else 'app/triggers/*.sql'
# Essayer d'exécuter tous les triggers dans le dossier qui les contient
for trigger in glob.glob(dossier):
sql = open(trigger).read()
try:
db.session.execute(sql)
db.session.commit()
print('Trigger {} crée sans erreurs.'.format(trigger))
except:
print('Erreur sur le trigger {}.'.format(trigger))
print('Triggers crées.')