[英]Insert data into mongodb collection
我想插入整個當前November
的數據,即本月的每一天和每一天的每一個小時以及每一小時的每一分鍾和每一分鍾的每一秒。 我嘗試了以下代碼,我嘗試了一天。
const data = [
{
'name': 'Name 10'
}, {
'name': 'Name 9'
}, {
'name': 'Name 8'
}, {
'name': 'Name 7'
}, {
'name': 'Name 6'
}, {
'name': 'Name 5'
}, {
'name': 'Name 4'
},
{
'name': 'Name 3'
},
{
'name': 'Name 2'
},
{
'name': 'Name 1'
}
];
const HOURS = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24];
const MINUTES = [0,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,50,51,52,53,54,55,56,57,58,59];
for (let i = 0; i < data.length; i++) {
for (let h = 0; h < HOURS.length; h++) {
const hour = new Date().setHours(HOURS[h]);
for (let m = 0; m < MINUTES.length; m++) {
const n = data[i].name;
const value = Math.floor(Math.random() * (10 - 0 + 1)) + 0;
const timestamp = new Date(hour).setMinutes(MINUTES[m]);
new MongoCollection({ 'name': n, 'value': value, 'timestamp': timestamp }).save();
}
}
}
任何幫助,將不勝感激。
為什么要創建 arrays 並使用HOURS.length
和MINUTES.length
? for (let h = 0; h < 24; h++)
和for (let m = 0; m < 60; m++)
也是如此。
- 0
和+ 0
的目的是什么?
一個接一個地插入文檔會導致嚴重的性能問題。
無論如何,我會建議moment.js庫,與此類似。
for (let d of data) {
var startTime = moment().startOf('month');
var endTime = moment().endOf('month');
var docs = [];
while (startTime.isBeforeOrSame(endTime)) {
docs.push({
name: d.name,
value: Math.floor(Math.random() * 11),
timestamp: startTime.toDate()
});
startTime.add(1, 'second');
}
db.collection.insertMany(docs);
}
或者甚至可以將數組docs
放在頂層。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.