Windows版本PostgreSQL定时备份

备份脚本

backup.bat备份脚本内容如下

bash 复制代码
@echo off
setlocal enabledelayedexpansion

:: 配置数据库连接参数
SET PGPASSWORD=******
SET DBUSR=postgres
SET DBHOST=localhost
SET DBPORT=5432
SET DBNAME=test

:: 配置路径
SET PGPATH="D:\Server\PostgreSQL\16\bin\pg_dump.exe"
SET BACKUP_DIR="D:\Server\PostgreSQL\Backup"

:: 使用日期时间生成备份文件名(格式:数据库名_年月日_时分秒.backup)
set datetime=%date:~0,4%%date:~5,2%%date:~8,2%_%time:~0,2%%time:~3,2%%time:~6,2%
set datetime=%datetime: =0% 
:: 处理小时为一位数时出现的空格
SET FILENAME=%DBNAME%_%datetime%.backup

:: 创建备份目录(如果不存在)
if not exist %BACKUP_DIR% mkdir %BACKUP_DIR%

:: 执行备份命令
echo 开始备份数据库 %DBNAME% ...
%PGPATH% -h %DBHOST% -p %DBPORT% -U %DBUSR% -F c -b -v -f "%BACKUP_DIR%\%FILENAME%" %DBNAME%

:: 检查备份是否成功
if errorlevel 1 (
    echo [错误] 数据库备份失败!
    exit /b 1
) else (
    echo 数据库备份成功完成:%BACKUP_DIR%\%FILENAME%
)

:: 可选:清理旧备份(例如,只保留最近10天的备份)
:: forfiles /p "%BACKUP_DIR%" /m *.backup /d -10 /c "cmd /c del /q @path"

配置定时备份

命令输入taskschd.msc后打开配置定时任务页面

相关推荐
踩坑小念12 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
John_ToDebug12 小时前
浏览器内核崩溃深度分析:从 MiniDump 堆栈到 BindOnce UAF 机制(未完待续...)
c++·chrome·windows
萧曵 丶13 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok14 小时前
MySQL的常用数据类型
数据库·mysql
曹牧14 小时前
Oracle 表闪回(Flashback Table)
数据库·oracle
J_liaty14 小时前
Redis 超详细入门教程:从零基础到实战精通
数据库·redis·缓存
一位赵14 小时前
小练2 选择题
linux·运维·windows
学***542314 小时前
12款分区恢复软件: 恢复已删除/丢失的分区
windows
m0_7066532314 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python
山岚的运维笔记14 小时前
SQL Server笔记 -- 第15章:INSERT INTO
java·数据库·笔记·sql·microsoft·sqlserver