Я пытаюсь вставить около 20 000 пользователей одновременно на свой сервер MSSQL из файла csv. Я создал API для своего приложения Angular2 и проанализировал файл csv в формате JSON. Но теперь я как бы застрял, я нашел ответ на этот вопрос более чем двухлетней давности, так что он больше не работает. Любая помощь?
Это код, который я уже использую:
//Insert gebruikers from CSV file
router.post('/gebruikers/csv', type, (req, res) => {
fs.readFile(req.file.path, 'utf8', function (err, csvData) {
if (err) {
res.send("error in file reader: " + err);
return console.log(err);
}
csvParser(csvData, {
delimiter: ',',
columns: true
}, function (err, json) {
if (err) {
res.send("error in csvParser: " + err);
console.log(err);
} else {
console.log(json);
//I think the query should be done here...
}
})
})
});
Заранее спасибо!!
ИЗМЕНИТЬ
Используя этот код прямо сейчас, он возвращает эту ошибку:
TypeError: parameter.value.getTime is not a function
Код:
router.post('/gebruikers/csv', type, (req, res) => {
fs.readFile(req.file.path, 'utf8', function (err, csvData) {
if (err) {
res.send("error in file reader: " + err);
return console.log(err);
}
csvParser(csvData, {
columns: true,
ltrim: true,
rtrim: true
}, function (err, json) {
if (err) {
res.send("error in csvParser: " + err);
console.log(err);
} else {
console.log(json);
const table = new sql.Table('[Alg].[User]');
table.create = true;
table.columns.add('Firstname', sql.NVarChar, { nullable: false });
table.columns.add('LastName', sql.NVarChar, { nullable: false });
table.columns.add('PrivateMail', sql.NVarChar, { nullable: false });
table.columns.add('UserName', sql.NVarChar, { nullable: false });
table.columns.add('Password', sql.NVarChar, { nullable: false });
table.columns.add('Auth', sql.NVarChar, { nullable: false });
table.columns.add('Enabled', sql.Bit, { nullable: false });
table.columns.add('Created', sql.SmallDateTime, { nullable: false });
table.columns.add('Manual', sql.Bit, { nullable: false });
table.columns.add('LastChanged', sql.SmallDateTime, { nullable: false });
table.columns.add('Staff', sql.Bit, { nullable: false });
var count = Object.keys(json).length;
console.log(count);
for (i = 0; i < count; i++) {
table.rows.add(json[i].Firstname, json[i].LastName, json[i].PrivateMail, json[i].UserName, json[i].Password, 'manual', 1, "GetDate()", 1, "GetDate()", 1);
}
console.log("Async function started!");
const request = new sql.Request();
request.bulk(table, (err, result) => {
// error checks?
if (err) {
console.log("ERROR post bulk gebruikers: " + err);
}
else {
res.send("SUCCES! " + result);
}
})
}
})
})
});
ИСПРАВЛЕНО
Как указал пользователь Григорий Чуднов, мне нужен экземпляр new Date()
. Я думал, что это не сработает, потому что это будет неправильный формат, но node-mssql справится с этим за меня.
currentDateTime = new Date();
table.rows.add(json[i].Firstname, json[i].LastName, json[i].PrivateMail, json[i].UserName, json[i].Password, 'manual', 1, currentDateTime, 1, currentDateTime, 1);
"GetDate()"
для типа данныхsql.SmallDateTime
, но должен быть экземплярDate
, например: new Date() - person Grigorii Chudnov   schedule 28.04.2017new Date()
, вы можете установить значение по умолчанию в схеме, например:CREATE TABLE ...... DEFAULT GETDATE()
, или написать необработанный SQL-запрос. - person Grigorii Chudnov   schedule 05.05.2017