SQL Server でのシーケンスの実装
多くのアプリケーションでは、さまざまな目的のために一意の連続した値を生成する機能が必要です。 GUID を使用することもできますが、すべての場合に最適であるとは限りません。さらに、個別のクエリによる値の挿入と取得は効率が悪い可能性があります。
解決策: シーケンス
SQL Server 2012 では、この目的のために特別に設計された SEQUENCE オブジェクトが導入されました。これらのオブジェクトを使用すると、テーブルとは独立して連続した数値を作成できます。
シーケンスの作成
シーケンスの作成は簡単です。
CREATE SEQUENCE Schema.SequenceName AS int INCREMENT BY 1 ;
これにより、順次整数値を生成する SequenceName という名前のシーケンスが作成され、値が増加します。 1.
シーケンスの使用
シーケンスを使用するには、NEXT VALUE FOR 関数を呼び出して、次に使用可能な値を取得します:
DECLARE @NextID int ; SET @NextID = NEXT VALUE FOR Schema.SequenceName; -- Some work happens INSERT Schema.Orders (OrderID, Name, Qty) VALUES (@NextID, 'Rim', 2) ;
この例では、SequenceName シーケンスから次の値が取得され、Orders 内の新しいレコードの OrderID として使用されます。 table.
シーケンスは、SQL Server でシーケンシャル値を生成するための信頼性が高く効率的な方法を提供し、面倒な回避策の必要性を排除します。
以上がSQL Server シーケンスで一意のシーケンシャル値を効率的に生成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。