ストアドプロシージャ内で@@ERRORと@@ROWCOUNTを併用で使用しています。下記URLでは問題ないかの様に記述されていますが、当方の環境では×です。下記の様なストアドです。
declare @errNo int
insert into ~
set @errNo = @@ERROR
if ( @errNo <> 0 )
return @errNo
if ( @@ROWCOUNT = 0 )
return 100
上記では、insert時のエラーは取得でき、@@ROWCOUNTは正常に1件挿入された場合でも、0が取得され、結果return 100が返される事になります。おそらく、@@ROWCOUNTの前でエラーハンドリングしている為、そこでリセット?されていると思われます。逆に、@@ROWCOUNTのハンドリングをエラーハンドリングより前にすると、今度は@@ROWCOUNTは正常に挿入された数が返ってくるものの、エラーハンドリングはされません。(おそらく、@@ROWCOUNTのハンドリング時に@@ERRORがリセットされる為と思われる。)この様な場合どうすればいいのでしょう?因みに以下のURLではOKらしいですが。。。
http://www.microsoft.com/japan/msdn/library/defa …
No.1ベストアンサー
- 回答日時:
こうしてください。
declare @errNo int
declare @rowcnt int
insert into ~
--↓ここでいっぺんに変数に格納してしまう
select @errNo = @@ERROR,@rowcnt = @@ROWCOUNT
if ( @errNo <> 0 ) --@@ERRORではない
return @errNo
if ( @@rowcnt = 0 ) --@@ROWCOUNTではない
return 100
ありがとうございます!ものの見事にうまくいきました。勉強になりました。それにしても、msdnのURLに記述されている例はなんなんでしょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAで、シート間の転記するコードをFOR~NEXTで教えてください。 9 2023/04/30 20:04
- PHP PHP MySql ページング 2 2022/09/20 06:38
- C言語・C++・C# C++のcase文の書き方 4 2023/02/24 20:50
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- Excel(エクセル) EXCELの外部データ取得ができない 1 2023/03/23 09:03
- Visual Basic(VBA) VBA 改行コードの取り方 1 2022/03/22 14:14
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- Visual Basic(VBA) VBAでの共有パスにつきまして 1 2023/03/04 17:24
- PHP phpのエラーについて 1 2022/06/27 22:30
- C言語・C++・C# C言語 3 2022/10/04 15:07
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Oracle 8i コンマ(,)を含むデ...
-
バッチファイルからのBCP起動に...
-
PostgreSqlでFunctionの作成に...
-
Access2000環境に対応するMid関...
-
エクセルのグループボックス枠...
-
SQLのエラー(~付近に不適切な...
-
GROUP BYでエラーが発生
-
@@ERRORと@@ROWCOUNT併用について
-
オブジェクト名 '<table>' が無...
-
ACCESS ADOでupdateが効かない
-
SQL SERVER の UNION ALL と GR...
-
SQLServerのエラー1069について
-
sqlで文字列を最後に追加したい
-
自作関数を含んだクエリをエク...
-
助けてください~~><
-
ORA-1036??
-
複数の表の外部結合について
-
リストボックスで選択したレコ...
-
ACCESSで作成したアプリケーシ...
-
Access Excelへ出力時にエラー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Oracle 8i コンマ(,)を含むデ...
-
SQLのエラー(~付近に不適切な...
-
バッチファイルからのBCP起動に...
-
エクセルマクロで指定範囲内の...
-
PostgreSqlでFunctionの作成に...
-
GROUP BYでエラーが発生
-
ACCESS ADOでupdateが効かない
-
sqlで文字列を最後に追加したい
-
エクセルからSQLサーバー ...
-
ACCESS2000ディスクまたはネッ...
-
オブジェクト名 '<table>' が無...
-
Access2000環境に対応するMid関...
-
ACCESSで作成したアプリケーシ...
-
エクセルのグループボックス枠...
-
レポートが開けない。
-
Accessのレポートが新規作成で...
-
@@ERRORと@@ROWCOUNT併用について
-
SQLserverのIF文について
-
SQLServer・ストアドプロシージ...
-
全ストアドを対象に文字列を置...
おすすめ情報