MSSQL 直前のINSERTされたIDENTITYの値を取得するには?

| コメント(0)

Microsoft SQL Server 2005からだったか、INSERTED.(フィールド名)というのが使えるようになっています。

IDENTITYの項目名がidとします。 下記のSQLを実行します。

                        INSERT INTO table_name(hogehoge) 
                        OUTPUT INSERTED.id 
                        VALUE ('hogehoge')

INSERT文によって生成されたidが取得できます。

C#(.NET)でMSSQL Serverを使うときは、SELECTと同じように扱って、値idを取得できます。

MSSQLでも2000までは、以下のIDENT_CURRENT@@IDENTITYSCOPE_IDENTITYというものを知らないといけなかったんですが、新しいバージョンだと不要です。


Transact-SQL リファレンス IDENT_CURRENT

  • IDENT_CURRENT は、任意のセッションと有効範囲内の特定のテーブルに対して生成された最後の ID 値を返します。 
  • @@IDENTITY は、すべての有効範囲を対象に、現在のセッション内の任意のテーブルに対して生成された最後の ID 値を返します。
  • SCOPE_IDENTITY は、現在のセッションと現在の有効範囲内の任意のテーブルに対して生成された最後の ID 値を返します。

 

コメントする

このブログ記事について

このページは、utが2009年6月25日 12:38に書いたブログ記事です。

ひとつ前のブログ記事は「MSSQL 数値を+1してINSERTする方法」です。

次のブログ記事は「Excelで出力するhtmlの文字コードを指定するには?」です。

最近のコンテンツはインデックスページで見られます。過去に書かれたものはアーカイブのページで見られます。

ウェブページ

Powered by Movable Type 5.04

にほんブログ村

にほんブログ村 IT技術ブログへ
にほんブログ村