重慶分公司,新征程啟航
為企業提供網站建設、域名注冊、服務器等服務
為企業提供網站建設、域名注冊、服務器等服務
上班有個需求,協助提取某數據系統中cashloanDb
成都創新互聯公司是一家集網站建設,曲水企業網站建設,曲水品牌網站建設,網站定制,曲水網站建設報價,網絡營銷,網絡優化,曲水網站推廣為一體的創新建站企業,幫助傳統企業提升企業形象加強企業競爭力。可充分滿足這一群體相比中小企業更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們為更多的企業打造出實用型網站。
涉及MongoDB集合: cardBill(時間段 6.1-8.28) , cardReport (時間段 2.1-8.28)
如果不支持根據時間提取,可提取全量數據。
使用mongo客戶端命令進入數據庫:
jsfkrs0:PRIMARY> show dbs;
2018-09-04T17:35:57.692+0800 E QUERY [thread1] Error: listDatabases failed:{
"ok" : 0,
"errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }",
"code" : 13,
"codeName" : "Unauthorized"
} :_getErrorWithCode@src/mongo/shell/utils.js:25:13
br/>_getErrorWithCode@src/mongo/shell/utils.js:25:13
br/>shellHelper.show@src/mongo/shell/utils.js:769:19
br/>@(shellhelp2):1:1
jsfkrs0:PRIMARY> use admin
switched to db admin
jsfkrs0:PRIMARY> db.auth('mangoadmin','password')
1
jsfkrs0:PRIMARY> show dbs;
admin 0.000GB
cashloanDb 96.287GB
fuf_mgdb 0.765GB
local 1.280GB
切換至我們要操作的db中
jsfkrs0:PRIMARY> use cashloanDb
switched to db cashloanDb
看一下這兩個集合的全量數據有多少
jsfkrs0:PRIMARY> db.cardBill.count();
247126
jsfkrs0:PRIMARY> db.cardReport.count();
249128
先看一下這個表里面有沒有時間戳我們取一條數據來看,有的話,我們可以基于這個時間戳來進行導出工作;
jsfkrs0:PRIMARY> db.cardBill.findOne();
{
"_id" : ObjectId("59e180110cxxxxxx"),
"timestamp" : NumberLong("1507950609625"),
"taskId" : "xxxxxx-b08d-11e7-bf17-xxxxx",
"bill" : "[{\"balance\":47000.00,\"deposits\":[],\"bills\":[{\"installments\":[],\"bill_id\":\"d81f1e60-a02d-11e7-a63a-00163e0dfac7\",\"bill_type\":\"DONE\",\"bank_name\":\"中信銀行\",\"bill_month\":\"2017-04\",\"bill_date\":\"2017-04-14\",\"payment_due
這個時間戳有13位,精確到了毫秒,我們在導出的時候需要換算成Unix時間戳,并且也精確到毫秒才可以。
http://tool.chinaz.com/Tools/unixtime.aspx
正常換算出來的只到秒位,只有10位。可以直接在換算出的Unix時間戳后面加000,或者換算的時候直接精確到毫秒,下來我們就可以用MangoDB自帶的導出工具進行導出;
mongoexport -d cashloanDb -c cardBill-uadmin -ppassword --authenticationDatabase "admin" -q '{"timestamp":{$gte:NumberLong("1517414400000"),$lte:NumberLong("1535472000000")}}' -o cardBill.json