-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathtable_config.js
48 lines (42 loc) · 1.5 KB
/
table_config.js
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
var fs = require('fs');
const utils = require('./util/utils')
const log = require("./config/log");
const db = require('./config/db')
const Sequelize = db.sequelize;
// const webMonitorIdList = require('./bin/webMonitorIdList')
var argv = process.argv
var commandLine = ""
var start = 0
var end = argv[2]
const handleCommandLine = (projectList) => {
projectList.forEach((proName, index) => {
for (var i = start; i < end; i ++) {
var dataStr = utils.addDays(i).replace(/-/g, "")
if (i == end - 1 && index == projectList.length - 1) {
commandLine += "node " + "table_create.js " + proName + " " + dataStr
} else {
commandLine += "node " + "table_create.js " + proName + " " + dataStr + " && "
}
}
})
fs.readFile('./package.json', function(err, data){
let newString = data.toString().replace(/table_create_command/g, commandLine)
fs.writeFile('./package.json', newString, (err) => {
if (err) throw err;
log.printInfo("命令配置完成, 请执行命令: npm run table_create");
});
})
}
// 获取项目列表
let sql = "select webMonitorId from Project"
Sequelize.query(sql, { type: Sequelize.QueryTypes.SELECT}).then((res) => {
let webMonitorIdList = []
res.forEach((p) => {
webMonitorIdList.push(p.webMonitorId)
})
if (webMonitorIdList.length) {
handleCommandLine(webMonitorIdList)
} else {
log.printError("未能查询到你的应用列表,无法创建对应的数据库表,请检查bin/webMonitorIdList.js文件")
}
})