Windows脚本导入导出Mongodb数据库文件实现备份与恢复

导出指定时间范围的数据

@echo off
setlocal
rem 提前将MongoDB安装的bin路径加到系统环境变量PATH里面,方便直接运行mongodump命令

if not exist D:\MongoDB_backup goto create

goto start    

:create

rem 如果没有创建导出文件目录,那么在此步骤创建
md D:\MongoDB_backup

rem 在备份路径下创建当天日期yyyyMM格式的文件夹保存数据库备份文件
for /f "tokens=2 delims==" %%a in ('wmic path win32_operatingsystem get LocalDateTime /value') do (
  set t=%%a
)
:: format date to yyyyMM
set fdate=%t:~0,6%
set yy=%t:~0,4%
set mm=%t:~4,2%
set dd=%t:~6,2%
rem 拼接当前日期
set date_str=%yy%-%mm%-%dd%
echo date_str is %date_str%
rem echo fdate is %fdate%

d:
cd D:\MongoDB_backup\

rem 以月份为单位创建目录
if not exist D:\MongoDB_backup\%fdate% goto createmm

:createmm
mkdir %fdate%

rem 以信号手段为单位创建目录
d:
cd D:\MongoDB_backup\%fdate%\
if not exist D:\MongoDB_backup\%fdate%\merge goto createmerge

:createmerge
mkdir %merge%



:: 定义日期范围 当前日期
set "start_date=%date_str%"

:: 将日期转换为UTC时间戳   因为是第二天备份前一天的数据,所以当前日期的时间戳为查询的结束日期
for /F "usebackq tokens=*" %%i in (`powershell -Command "Get-Date -Date '%start_date%' -UFormat '%%s'"`) do (
    set "end_timestamp=%%i"
)

:: 计算下一天的日期
set /a "start_timestamp=end_timestamp-86400"


:start

rem 将时间戳转换为日期对象,用于导出文件命名
for /F "usebackq tokens=*" %%i in (`powershell -Command "([datetime]'1970-01-01').AddMilliseconds(%start_timestamp%000).ToString('yyyyMMdd')"`) do (
    set "formatted_date=%%i"
)

:: 导出数据到指定目录
mongoexport --host localhost --port 27017 --db test --collection testMongodbUser1 --query "{ \"createTime\": { \"$gte\": { \"$date\": { \"$numberLong\": \"%start_timestamp%000\" } }, \"$lt\": { \"$date\": { \"$numberLong\": \"%end_timestamp%000\" } } } }" --out "D:\MongoDB_backup\202309\merge\%formatted_date%.json"

endlocal

导入数据

@echo off
setlocal

:: 定义导入文件路径
set "import_file=D:\MongoDB_backup\202309\merge\20230920.json"

:: 定义目标数据库和集合名
set "database=test"
set "collection=testMongodbUser4"

:: 导入文件到 MongoDB
mongoimport --db %database% --collection %collection% --file %import_file%

endlocal

你可能感兴趣的:(数据库,windows,mongodb)