This repository was archived by the owner on Aug 16, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.ts
More file actions
40 lines (31 loc) · 1.39 KB
/
index.ts
File metadata and controls
40 lines (31 loc) · 1.39 KB
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
import fs = require('fs')
import db = require('./db')
const tables = [
'auteurs_histoires',
'histoires_publications',
'utilisateurs_histoires_manquantes',
'utilisateurs_publications_manquantes',
'utilisateurs_publications_suggerees'
]
const dbName = process.env.MYSQL_DM_STATS_DATABASE
db.connect().then(async () => {
await db.runQuery(`DROP DATABASE IF EXISTS ${dbName}_new`)
await db.runQuery(`CREATE DATABASE ${dbName}_new`)
for (const dbName2 of [dbName, `${dbName}_new`]) {
await db.runQuery(`USE ${dbName2}; ${fs.readFileSync('sql/ddl/create-stats-tables.sql').toString()}`)
}
await db.runQuery(fs.readFileSync('sql/create-stories-publications.sql').toString())
await db.runQuery(fs.readFileSync('sql/create-authors-stories.sql').toString())
await db.runQuery(fs.readFileSync('sql/create-users-missing-stories.sql').toString())
await db.runQuery(fs.readFileSync('sql/create-users-missing-issues.sql').toString())
await db.runQuery(fs.readFileSync('sql/create-users-suggested-issues.sql').toString())
await db.runQuery(`DROP DATABASE IF EXISTS ${dbName}_old`)
await db.runQuery(`CREATE DATABASE ${dbName}_old`)
for (const table of tables) {
await db.runQuery(`RENAME TABLE
${dbName}.${table} TO ${dbName}_old.${table},
${dbName}_new.${table} TO ${dbName}.${table}`
)
}
await db.disconnect()
})