作为Java开发人员,数据库的备份估计也算是必学的了。
遗憾的是我一直在做前后台的业务逻辑处理,数据库运维没有怎么接触。
今天看了一个bat文件,是在dos下的文件复制和MySQL数据备份的命令,
学习并记录下,以便什么时候用上。
一、dos下的文件复制
@echo off @echo 开始程序目录备份 XCOPY D:\test E:\work\back%Ymd% /y /e /i @echo 程序目录备份完成 @echo on pause
1.@echo off 命令是关闭显示dos命令执行过程的的每条命令
相应@echo on 命令就是打开了
2.XCOPY 命令是把前一个目录下的所有文件和目录复制到后一个文件中
3.%Ymd%这个就是开发人员熟悉的日期格式表达式。C:\Documents and Settings\Administrator>xcopy /?
4./y /e /i 看看下面解释
xcopy /? 在dos下执行该命令可以查看复制的所有相关命令,如下
C:\Documents and Settings\Administrator>xcopy /?
XCOPY source [destination] [/A | /M] [/D[:date]] [/P] [/S [/E]] [/V] [/W]
[/C] [/I] [/Q] [/F] [/L] [/G] [/H] [/R] [/T] [/U]
[/K] [/N] [/O] [/X] [/Y] [/-Y] [/Z]
[/EXCLUDE:file1[+file2][+file3]...]
source 指定要复制的文件。
destination 指定新文件的位置和/或名称。
/A 只复制有存档属性集的文件,
但不改变属性。
/M 只复制有存档属性集的文件,
并关闭存档属性。
/D:m-d-y 复制在指定日期或指定日期以后更改的文件。
如果没有提供日期,只复制那些源时间
比目标时间新的文件。
/EXCLUDE:file1[+file2][+file3]...
指定含有字符串的文件列表。每一个字符串
必须在文件的单独行中。如果有任何
字符串与要被复制的文件的绝对路径
相符,那个文件将不会得到复制。
例如,指定如 \obj\ 或 .obj 的字符串会排除
目录 obj 下面的所有文件或带有
.obj 扩展名的文件。
/P 创建每个目标文件前提示。
/S 复制目录和子目录,除了空的。
/E 复制目录和子目录,包括空的。
与 /S /E 相同。可以用来修改 /T。
/V 验证每个新文件。
/W 提示您在复制前按键。
/C 即使有错误,也继续复制。
/I 如果目标不存在,又在复制一个以上的文件,
则假定目标一定是一个目录。
/Q 复制时不显示文件名。
/F 复制时显示完整的源和目标文件名。
/L 显示要复制的文件。
/G 允许将没有经过加密的文件复制到
不支持加密的目标。
/H 也复制隐藏和系统文件。
/R 覆盖只读文件。
/T 创建目录结构,但不复制文件。
不包括空目录或子目录。/T /E 包括
空目录和子目录。
/U 只复制已经存在于目标中的文件。
/K 复制属性。一般的 Xcopy 会重置只读属性。
/N 用生成的短名复制。
/O 复制文件所有权和 ACL 信息。
/X 复制文件审核设置(隐含 /O)。
/Y 复制文件审核设置(隐含 /O)。
现存目标文件。
/-Y 导致提示以确认改写一个
现存目标文件。
/Z 用重新启动模式复制网络文件。
命令行开关 /Y 可以预先在 COPYCMD 环境变量中设置。
这可能被命令行上的 /-Y 改写。
5.@echo 输出一个提示语句(自定义)
6.pause暂停
二、MySQL数据备份
@echo off @echo 正在进行数据库备份 mysqldump --opt -uroot --password=root oa >E:\work\back\db.sql @echo 数据库备份完成 @echo on pause
mysqldump --opt -uroot --password=root oa >E:\work\back\db.sql
MySQL备份命令 用户名 密码 数据库名 备份地址
mysqldump 该命令需要在MySQL数据安装路径下的bin目录中执行,否则会报找不到的内部或外部命令
MySQL数据备份的例子百度上很多,有空再学习整理。
这些命令很容易看懂,也很简单,但是还是需要亲自实践一下为好,毕竟纸上得来终觉浅。