web-dev-qa-db-ja.com

SQL Server SEQUENCEから現在の値を取得します

シーケンスから現在の値を取得したい-シーケンスプロパティウィンドウSQL Server Management Studioに表示される値と同じ値

enter image description here

私のシーケンスは次のステートメントで作成されます。

CREATE SEQUENCE [OrderNumberSequence]
    as int
    START WITH 4000
    INCREMENT BY 1
    MINVALUE 0
    NO MAXVALUE
    NO CACHE;
GO

私はこれを試しました MSDNのSQL –しかし、結果は、クエリを実行するたびに私の数が5ずつ増加するということです

DECLARE  
  @FirstSeqNum sql_variant
, @LastSeqNum sql_variant
, @CycleCount int
, @SeqIncr sql_variant
, @SeqMinVal sql_variant
, @SeqMaxVal sql_variant ;

EXEC sys.sp_sequence_get_range
@sequence_name = N'[OrderNumberSequence]'
, @range_size = 5
, @range_first_value = @FirstSeqNum OUTPUT 
, @range_last_value = @LastSeqNum OUTPUT 
, @range_cycle_count = @CycleCount OUTPUT
, @sequence_increment = @SeqIncr OUTPUT
, @sequence_min_value = @SeqMinVal OUTPUT
, @sequence_max_value = @SeqMaxVal OUTPUT ;

-- The following statement returns the output values
SELECT
  @FirstSeqNum AS FirstVal
, @LastSeqNum AS LastVal
, @CycleCount AS CycleCount
, @SeqIncr AS SeqIncrement
, @SeqMinVal AS MinSeq
, @SeqMaxVal AS MaxSeq ;

数値を変更せずに値を取得する方法はありますか?

31
Henrik Stenbæk

current_valueからsys.sequencesを選択できます:

SELECT current_value FROM sys.sequences WHERE name = 'OrderNumberSequence' ;

[〜#〜] demo [〜#〜]

53
Tim Schmelter