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

Contents1 SQLでIFを使わずに条件分岐する1.1 1.テーブルとデータの準備1.2 2.条件を分岐させて検索1.3 3.解説 SQLでIFを使わずに条件分岐する SQLでIFを書けばWHE ...

SQLServer 3

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

4

Contents1 SQLServerでテーブル型を戻り値とする関数を作る1.1 テーブル型を戻り値とする関数の作成1.2 呼び出しかた SQLServerでテーブル型を戻り値とする関数を作る SQL ...

5

Contents1 アフィリエイトで即効成果を出す1.1 自分で買えば確実に成果が上がる1.2 A8.netでは自分で購入してもOKなものがある1.2.1 A8.netにサイトを登録する1.2.2 承 ...

-SQL Server
-,

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