中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 【求助】DOS下实现数据库自动还原(需要增加一些代码)
作者:
标题: 【求助】DOS下实现数据库自动还原(需要增加一些代码) 上一主题 | 下一主题
creda
新手上路





积分 12
发帖 10
注册 2008-12-30
状态 离线
『楼 主』:  【求助】DOS下实现数据库自动还原(需要增加一些代码)

@ECHO off

REM restore Database Script Log Files
SET dbbak_dir=d:\test\full back\
SET logbak_dir=d:\test\log\
if not exist %logbak_dir% mkdir %logbak_dir%

  此次需要求助的代码
监控d:\test\full back\ 文件夹和d:\test\log\文件夹 这两个文件夹中文件的更新情况,如果出现新增文件,就将文件名(不包含扩展名)作为值赋给下面代码中标为红色的变量F_filename和L_filename


REM restore Database Name
SET A_Database_Name=test
SET A_DATE=%date:~0,4%
SET F_filename=
SET L_filename=

此处求助代码
如果F_filename和L_filename等于amino_db_%date:~0,4%0040或amino_db_%date:~0,4%1240  就执行restore处代码,或者输出字符“无!”


REM restore


ECHO use master >%dbbak_dir%FULL_restore_test.sql

rem ECHO SP_ADDUMPDEVICE 'DISK',>>%dbbak_dir%FULL_restore_test.sql
rem ECHO '%F_filename%', >>%dbbak_dir%FULL_restore_test.sql
rem ECHO '%dbbak_dir%%F_filename%.bak'; >>%dbbak_dir%FULL_restore_Amino.sql
rem ECHO go >>%dbbak_dir%FULL_restore_test.sql
ECHO restore DATABASE %A_Database_Name% >>%dbbak_dir%FULL_restore_test.sql
ECHO from DISK = '%dbbak_dir%%F_filename%.bak' >>%dbbak_dir%FULL_restore_test.sql
echo with move 'test_Data' to 'C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf',>>%dbbak_dir%FULL_restore_test.sql
echo move 'test_log' to 'C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf',>>%dbbak_dir%FULL_restore_test.sql
ECHO norecovery >>%dbbak_dir%FULL_restore_test.sql

rem ECHO SP_ADDUMPDEVICE 'DISK',>>%dbbak_dir%FULL_restore_test.sql
rem ECHO '%F_filename', >>%dbbak_dir%FULL_restore_test.sql
rem ECHO '%dbbak_dir%%L_filename.trn'; >>%dbbak_dir%FULL_restore_test.sql
rem ECHO go >>%dbbak_dir%FULL_restore_test.sql
ECHO restore log %A_Database_Name% >>%dbbak_dir%FULL_restore_test.sql
ECHO from DISK = '%dbbak_dir%%L_filename.trn' >>%dbbak_dir%FULL_restore_test.sql
ECHO go >>%dbbak_dir%FULL_restore_test.sql
ECHO .




REM isql.exe path
SET iSQL_PATH=C:\Program Files\Microsoft SQL Server\80\Tools\Binn\

REM Database user name and password
SET DBUser=user
SET DBpassword=1111111
ECHO restore DATABASE
"%iSQL_PATH%isqlw.exe" -d %A_Database_Name%  -U %DBUser% -P %DBpassword% -i "%dbbak_dir%FULL_restore_Amino.sql"  -o "%dbbak_dir%result_Amino.txt"


echo .

REM delete file
  move /y  %dbbak_dir%FULL_restore_test.sql    %logbak_dir%

  move /y %dbbak_dir%result_test.txt                    %logbak_dir%
                  
echo .

[ Last edited by creda on 2009-1-7 at 17:18 ]

2009-1-7 17:08
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
creda
新手上路





积分 12
发帖 10
注册 2008-12-30
状态 离线
『第 2 楼』:  

居然没人理会

2009-1-8 17:59
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: