SQL Server

@@ROWCOUNTで処理した件数を取得する

投稿日:2014/03/04 更新日:

@@ROWCOUNTは直前に処理した件数を取得するための関数

SQLServerでは実行したSQLで影響を与えた処理件数を
@@ROWCOUNTを使用することで取得できます。






@@ROWCOUNTで処理件数を取得する

まずはInsertした処理件数を取得します。

上記のSQLを実行すると

となり、INSERTで最後のステートメントの影響を受けた処理件数は
1件になります。
当たり前ですね。

でも、1行のINSERT文で複数のデータを挿入する方法のように
1行のINSET文で複数行データを挿入すると

の実行結果は

のようにちゃんと挿入した処理件数を@@ROWCOUNTが取得してくれます。

@@ROWCOUNTで更新件数を取得する

更新でも同様に

になります。

@@ROWCOUNTで削除件数を取得する

削除も

になり、処理件数が取得できます。

@@ROWCOUNTの注意事項

@@ROWCOUNTは直前のステートメントで影響を受けた件数なので

とすると2行目のPRINTで表示されている@@ROWCOUNTは1行目のPRINTを
表示した時点でクリアされるので

と0になってしまいます。
あとで「@@ROWCOUNT」の値を利用したい場合は
他の変数に保存しておく必要があります。

当サイトのおすすめ記事

レンタルサーバー 1

当サイトは約5年間、さくらのレンタルサーバで運用させて頂きました。 何かトラブルがあったわけではないのですが、WordPressの表示速度を速くしたくてSSD搭載のレンタルサーバーで運用してみることに ...

プログラミング 2

SQLでIFを使わずに条件分岐する SQLでIFを書けばWHERE句の内容を変えて検索できますが、条件ごとに同じようなSQLを 複数回書くのは面倒なので、1行で分岐できないかと言う事でSQLを作って見 ...

SQLServer 3

SQLServerで発生するエラーコードをSQLで取得する SQLServerで発生したエラーコードの内容を メッセージが定義されているテーブルから取得します。 エラーコードを取得するSQL SQLs ...

4

SQLServerでテーブル型を戻り値とする関数を作る SQLServerではINT型やVARCHAR型などを返す関数と同様に ユーザー定義テーブル型を戻り値とする関数を作成できます。 テーブル型を戻 ...

5

アフィリエイトで即効成果を出す アフィリエイトで成果を出す、なかなか難しいですよね。 サイトをいくつも立ち上げてすでにコツをつかんでいる人なら チョチョイっとやっていけるんでしょうけど。 でも実際はこ ...

-SQL Server
-,

Copyright© ソフトウェア開発日記 , 2017 AllRights Reserved.