| 利用WSH作定時工作排程 | |
| 日期:2001年1月15日 作者:sos12345(转贴) 人气: 3264 今日:1 [大 中 小] | |
|
當然你可以在命令列執行 IE 並告訴它要求執行的網頁, 例如: c:\program files\internet explorer\iexplore.exe http://localhost/mypage.asp, 不過, 這絕對不是大部分的網站管理者所要的方法, 因為這必須要開啟瀏覽器, 花費許多的系統資源, No Good! 此外, 還有一個缺點, 那就是執行 ASP 網頁有逾時時間 (Timeout), 如果你要執行許多的排程工作, 你可能要更改 Timeout 時間, 哇! 太麻煩! No good! 在這一篇文章要介紹的是使用 WSH (Windows Scripting Host) 的解決方案 WSH 的安裝
假設你現在有一個廣告輪撥系統, 你想將檢查廣告到期日這件工作自動化每天凌晨執行, 也就是當一則廣告過期了, 便將其廣告狀態更改為停用, 我們先來看看資料表 AdInfo 欄位 AdId 廣告代碼 Int
不需加上 ASP 分隔符號 ''請勿用 Server.CreateObject 將檔案存為 c:\scripts\updateadstatus.vbs, WSH 有兩個版本, 一為視窗版 (wscript.exe), 一為命令列版 (cscript.exe), 在這個例子我們將使用 (cscript.exe), 你可以在 DOS 命令列下執行 c:\>cscript c:\scripts\updateadstatus.vbs 接著你可以到 Query Analyzer 下查詢資料是否更新, 在實際的應用上, 建議你使用批此檔來區分不同時段的工作, 好比說我會創造一支名為 dailytask.bat 的批次檔來執行所有的每日例行工作, 如此一來, 我只需將所有每日應執行的 script 放到這支批次檔即可, 然後利用 AT Command 或是 SQL Server Agent 定時每日執行 dailytask.bat 強烈建議使用 SQL Server Agent, 這會比使用 AT Command 來得有效率且穩定! 設定 SQL Server Agent 你可以執行 Enterprise Manager, 展開後會看到這樣的畫面
|
