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

本文介绍了一种使用按键精灵实现SQL Server Express自动备份的方法。通过编写脚本自动化打开SQL Server Management Studio,选择数据库并导出SQL文件,最后使用批处理文件进行增量备份。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


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


 

屏幕取词程序VC源码 nhw32.dll 主要引出两个函数: 1. DWORD WINAPI BL_SetFlag32(UINTnFlag, HWND hNotifyWnd, int MouseX, int MouseY) 功能: 启动或停止取词。 参数: nFlag [输入] 指定下列值之一: GETWORD_ENABLE: 开始取词。在重画被取单词区域前设置此标志。 nhw32.dll是通过 重画单词区域,截取TextOutA, TextOutW,ExtTextOutA, ExtTextOutW等Windows API函数的参数来取词的。 GETWORD_DISABLE: 停止取词。 hNotifyWnd [输入] 通知窗口句柄。当取到此时,向该通知窗口发送一登记消息: GWMSG_GETWORDOK。 MouseX [输入] 指定取词点的X坐标。 MouseY [输入] 指定取词点的Y坐标。 返回值: 可忽略。 2. DWORD WINAPI BL_GetText32(LPSTRlpszCurWord, int nBufferSize, LPRECT lpWordRect) 功能: 从内部缓冲区取出单词文本串。对英语文本,该函数最长取出一行内以 空格为界的三个英文单词串,遇空格,非英文字母及除‘-’外的标点符 号,则终止取词。对汉字文本,该函数最长取出一行汉字串,遇英语字 母,标点符号等非汉语字符,则终止取词。该函数不能同时取出英语和 汉语字符。 参数: lpszCurWord [输入] 目的缓冲区指针。 nBufferSize [输入] 目的缓冲区大小。 lpWordRect [输出] 指向 RECT 结构的指针。该结构定义了被取单词所在矩形区域。 返回值: 当前光标在全部词中的位置。 此外,WinNT/2000版nhw32.dll 还引出另两个函数: 1. BOOL WINAPI SetNHW32() 功能: Win NT/2000 环境下的初始化函数。一般在程序开始时,调用一次。 参数: 无。 返回值: 如果成功 TRUE ,失败 FALSE 。 2. BOOL WINAPI ResetNHW32() 功能: Win NT/2000 环境下的去初始化函数。一般在程序结束时调用。 参数: 无。 返回值: 如果成功 TRUE ,失败 FALSE
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值