zoukankan      html  css  js  c++  java
  • 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


     

  • 相关阅读:
    [extjs] ExtJs4.2 Form 表单提交
    [java ] java.util.zip.ZipException: error in opening zip file
    Oracle 11g 执行计划管理1
    Oracle 分区表的统计信息实例
    Oracle 手动收集统计信息
    Oracle 10g 之自动收集统计信息
    Oracle 11g 之自动收集统计信息
    Oracle 11gR2 RAC修改SCAN IP
    共享内存shared pool (6):追踪sql语句
    共享内存shared pool (5):详解一条SQL在library cache中解析
  • 原文地址:https://www.cnblogs.com/attilax/p/15199923.html
Copyright © 2011-2022 走看看