VBSでADO接続に失敗した場合にフリーズするのですが、何とか
ならないでしょうか。
以下、わたしのコード(戻り値を返(WSCript.Quit Err.Number)したいので、On Error Resume Nextは外せません。)
Option Explicit
On Error Resume Next
Dim objADO
Set objADO = CreateObject("ADODB.Connection")
objADO.Open "Driver={SQL Server};server=" & WScript.Arguments(0) & _
"; database=" & WScript.Arguments(1) & _
";uid=" & WScript.Arguments(2) & _
";pwd=" & WScript.Arguments(3) & ";"
objADO.Execute(WScript.Arguments(4))
objADO.Close
Set objADO = Nothing
WSCript.Quit Err.Number
No.1ベストアンサー
- 回答日時:
よく、On Error Resume Nextを先頭に置いたスクリプトを見かけますが、
まるで、Option Explicitをスクリプトの先頭に置くような感覚で、
「適当にエラーをリカバるオプション」のような誤解があるのではないでしょうか。
On Error Resume Nextの意味は、言わば、
「エラーがあっても無視して、どうなってもいいから暴走しろ」ですから、
そんな、自暴自棄に走らなくても、と思ってしまいます。
そのような時は、きちんとエラー判定を行い、適切な処理をしましょう。
例1では、Openしかエラー判定を行っていませんが、Executeもエラーが起こりそうなのでエラー判定を行ってください。
ようは、Resume Nextを使うなら、エラーが起こりそうなところで、適切なエラー処理を行わなければいけないと言うことです。
例1
sub 処理1
Option Explicit
On Error Resume Next
Dim objADO
Set objADO = CreateObject("ADODB.Connection")
objADO.Open "Driver={SQL Server};server=" & WScript.Arguments(0) & _
"; database=" & WScript.Arguments(1) & _
";uid=" & WScript.Arguments(2) & _
";pwd=" & WScript.Arguments(3) & ";"
if Err.Number <> 0 then
else
objADO.Execute(WScript.Arguments(4))
objADO.Close
end if
Set objADO = Nothing
WSCript.Quit Err.Number
End Sub
例2
sub 処理1
Option Explicit
'On Error Resume Next
On Error GoTo Err処理
Dim objADO
Set objADO = CreateObject("ADODB.Connection")
objADO.Open "Driver={SQL Server};server=" & WScript.Arguments(0) & _
"; database=" & WScript.Arguments(1) & _
";uid=" & WScript.Arguments(2) & _
";pwd=" & WScript.Arguments(3) & ";"
objADO.Execute(WScript.Arguments(4))
objADO.Close
Set objADO = Nothing
Exit Sub
Err処理:
Set objADO = Nothing
WSCript.Quit Err.Number
End Sub
注:全角空白があるのでそのまま貼り付けないで。
わたしの求めている回答のほか、プログラミングをする上での哲学まで教えて頂き非常に感謝しております。残念ながら、わたしの周囲にはあなたのようなプログラマーはおりません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
これ何て呼びますか Part2
あなたのお住いの地域で、これ、何て呼びますか?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
[Access] パススルークエリーで実行すると遅い
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
UserForm1.Showでエラーになり...
-
On ErrorでエラーNoが0
-
VBAでfunctionを利用しようとし...
-
Filter関数を用いた結果、何も...
-
HTMLソースが表示のページのも...
-
String""から型'Double'への変...
-
天狗のネタ帳でスクリプトエラ...
-
お助けください!VBAのファイル...
-
エクセルでリンクされたイメー...
-
検索Find処理を2重、3重とす...
-
インポート時のエラー「データ...
-
文字列内で括弧を使うには
-
Maximaでのエラーメッセージ
-
演算子が DBnull 及び integer...
-
VB6とVB.NETでNullの扱いが違う?
-
フランスの生年月日(jj/mm/aaaa)
-
実行時エラー 438 の解決策をお...
-
Python openpyxlを使用したセル...
-
教えてください。FTPアップロー...
-
マクロで"#N/A"のエラー行を削...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
UserForm1.Showでエラーになり...
-
VBAでfunctionを利用しようとし...
-
【VBA】ワークブックを開く時に...
-
文字列内で括弧を使うには
-
Pythonでの文字列からfloatへの...
-
String""から型'Double'への変...
-
On ErrorでエラーNoが0
-
お助けください!VBAのファイル...
-
2つほどお聞きしたいことがあり...
-
マクロで"#N/A"のエラー行を削...
-
Excel vbaについての質問
-
【VBAエラー】Nextに対するFor...
-
実行時エラー 438 の解決策をお...
-
実行時エラー'-2147467259(8000...
-
ACCESSで値を代入できないとは?
-
VBA データ(特定値)のある最...
-
「実行時エラー '3167' レコー...
-
【VB.NET】 パワポ操作を非表示で
-
マクロの「SaveAs」でエラーが...
-
ApplicationとWorksheetFunctio...
おすすめ情報