日期:2014-05-16  浏览次数:20410 次

paip.提高开发效率----自动数据库SQL备份


paip.提高开发效率----自动数据库SQL备份


因为不断的更改数据库SQL结构,希望每天晚上可以把导出SQL,放入项目,然后增量备份..


企业版的SQL的有自动任务,可以设置自动导出SQL。。


而我的SQL2008 EXPRESS。。没有办法自动导出。只能手工操作..


经过我的一番努力,终于找到个方法了。。就是使用按键精灵9.0,制作一款EXE,可以自动操作SQL服务器,然后在批处理中调用,就一切OK了。

开始编写精灵脚本:

//运行SQL2008管理器
RunApp "C:\Program Files\Microsoft SQL Server\100\Tools\Binn\VSShell\Common7\IDE\ssms.exe"
//延时,为了下面的查找窗口句柄做准备。如不延时,可能找不到窗口句柄
Delay 2000

//查找窗口类名(0)或者标题 ,返回找到的句柄Hwnd..这个是个登录窗口。
Hwnd = Plugin.Window.Find(0, "连接到服务器")
//激活窗口
Call Plugin.Window.Active(Hwnd)

//按下ALT+C,相当于点击了界面上的“连接”按钮,进行连接SQL服务器.
 KeyDown 18, 1
KeyPress 67, 1
KeyUp 18, 1

//需要等待登录窗口消失.
Delay  2000


//来到主窗口
HwndMax = Plugin.Window.Find(0, "Microsoft SQL Server Management Studio")
//最大化窗口,以方便进行鼠标录制.定位操作。
Call Plugin.Window.Max(HwndMax)

 

//未注册版本将来编译成EXE会有个广告窗口出现在右下方,这里找到此窗口,隐藏起来..
HwndAd = Plugin.Window.Find("AfxFrameOrView42", "")
 
Call Plugin.Window.Hide(HwndAd)


//----------以下是一系列鼠标录制操作,一就展开左边的树形结点,找到要导出SQL的数据库》任务》生成脚本
Delay 754
MoveTo 807, 469
Delay 7
MoveTo 825, 470
****此处省略几百行..


//此时打开了“生成脚本”的窗口


Delay  1000

Hwnd8 = Plugin.Window.Find(0, "脚本向导 - HOPE\SQLEXPRESS")
Call Plugin.Window.Active(Hwnd8)
Delay  500
//最大化窗口
Call Plugin.Window.Max(Hwnd8)


//一系列鼠标录制操作,完成导出SQL的操作。。并关闭进程...
'==========以下是按键精灵录制的内容==========
Delay 754
MoveTo 807, 469
Delay 7
MoveTo 825, 470
Delay 41
****此处省略几百行..

//----------------------------------脚本结束-----------------------


这样,一个脚本文件就结束了,编译成baksql.exe...然后编写批处理文件,以便自动调用


//如果进程存在,就等待,直到BAKSQL完成导出SQL的操作..
set taskname="C:\Users\Administrator\Desktop\cbgl\baksql.exe"
 
%taskname%

set tasknameShort="baksql.exe"
:start
tasklist   /FI "IMAGENAME eq %tasknameShort%"    | find /i "%tasknameShort%"
if %ERRORLEVEL% EQU 0 GOTO :start
:end

//COPY至项目目录
copy /y "C:\Users\Administrator\Documents\script.sql"   "C:\Users\Administrator\Desktop\cbgl\script.sql"

//使用WINRAR增量备份
"C:\Program Files\WinRAR\rar.exe" a   -ep1 -m1 -r -n*.txt -n*.doc -n*.cs -n*.csproj -n*.sln -n*.resx -n*.sql -n*.config -n*.xsd -n*.settings   -ta2012-07-20-01:01:01  %zipname%  "C:\Users\Administrator\Desktop\cbgl"
pause