🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1066閲覧

Python でSQL Serverのジョブを実行しており、実行状況を把握したい(例外をキャッチしたい)

saya24

総合スコア246

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/03/13 15:54

編集2021/03/13 16:25

以下は Pythonで SQLServerのジョブを実行している部分です。
データベース側で確認すると 明らかにジョブの実行に失敗しているのが 現況ですが Python側で 例外がキャッチされない状況です。
一応戻り値を 得ているのですが  そちらがどういう状態だったら 失敗と判断して 例外を故意に発生させれば よいのでしょうか?
失敗

どなたかご教示いただけないでしょうか、宜しくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

SQLSERVERインストールしてないのでネットで検索した結果から記載します。
→インストールして確認してみました。

sysjobhistory
sysjobs

SQL

1select TOP 1 a.run_status from msdb.dbo.sysjobhistory a 2join ( 3 select * from msdb.dbo.sysjobs 4 where name = 'ジョブ名' 5) b on (a.job_id = b.job_id) 6order by a.run_date DESC,a.run_time DESC;;

この結果が1の場合は成功、0の場合は失敗のようですね。

投稿2021/03/13 22:10

編集2021/03/14 00:26
xail2222

総合スコア1508

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

saya24

2021/03/13 23:57 編集

ご見解ありがとうございます。わざわざ当方のためにインストールまでして頂かなくて結構ですよ。エクスプレス版だとジョブの実行は出来ないかもしれませんし。 データベース側に再度確認しにいかなければならないのかが気になりますね。 そういうものかな??? どなたか存じ上げないでしょうか
saya24

2021/03/14 00:21

ジョブがコケたかジョブがコケないかは もうジョブ側の責任範囲と考えるべきか!!! 最近一人で物事を進めることで 視野が狭くなっている自分に気がつく。
xail2222

2021/03/14 00:37 編集

インストールしてみて確認して回答を修正しました。 確かにはじめエクスプレス版をインストールして出来なかったので ディベロッパー版をインストールしなおして確認しました。 ※VMwareにテスト用の環境を作って確認してます。 あとmsdb.dbo.sp_start_jobの結果ですが これはジョブの呼び出しが成功したかであり ジョブの実行の結果が返ってくるわけではないようです。 非同期に実行されてるのかな。 であれば即座に結果が返ってくるわけではないので 呼び出し時間以降の結果が返ってくるまで繰り返さないといけないですね。
saya24

2021/03/14 00:40

xail2222さん どれだけ親切なのぉ~と驚きを隠せない自分です。 ジョブ側にコケた場合の通知責任を持たせるようにします。貴重なお時間を頂いてしまい申し訳ございませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問