ホームページ データベース mysql チュートリアル sequence的MAXVALUE、NOMAXVALUE和CYCLE、NOCYCLE参数

sequence的MAXVALUE、NOMAXVALUE和CYCLE、NOCYCLE参数

Jun 07, 2016 pm 03:56 PM
c

Oracle的sequence通常可以用来作自增列,例如主键,因为他可以自动累加并且唯一。创建sequence时有几个参数,MAXVALUE、MINVALUE、CYCLE、NOCYCLE、NOMAXVALUE等,这几个参数我们日常使用的时候可能不会太在意,但有些细节问题碰到的时候就需要明确下。 1、

Oracle的sequence通常可以用来作自增列,例如主键,因为他可以自动累加并且唯一。创建sequence时有几个参数,MAXVALUE、MINVALUE、CYCLE、NOCYCLE、NOMAXVALUE等,这几个参数我们日常使用的时候可能不会太在意,但有些细节问题碰到的时候就需要明确下。

1、未定义NOCYCLE,默认是NOCYCLE还是CYCLE?

CREATE SEQUENCE test_seq
start with 1
increment by 1
MAXVALUE 2
cache 20;

SELECT test_seq.nextval FROM DUAL;取值为1。

SELECT test_seq.nextval FROM DUAL;取值为2。

SELECT test_seq.nextval FROM DUAL;报错:ORA-08004: sequence TEST_SEQ.NEXTVAL exceeds MAXVALUE and cannot be instantiated,说明未指定的情况下,默认是NOCYCLE。

2、未定义MAXVALUE,默认是MAXVALUE还是NOMAXVALUE?

CREATE SEQUENCE tes_seq
start with 1
increment by 1
cache 20;

查看MAXVALUE取值是999999999999999999999999999,说明默认是MAXVALUE。

3、MAXVALUE最大值究竟是多少?

CREATE SEQUENCE tes_seq
start with 1

maxvalue 29个9
increment by 1
cache 20;

提示:ORA-04003:sequence parameter MAXVALUE exceeds maximum size allowed (28 digits)

说明最大允许28位。

创建了28位的MAXVALUE,并且设置CYCLE:

CREATE SEQUENCE test_seq
start with 9999999999999999999999999998
MAXVALUE 9999999999999999999999999999
increment by 1
CYCLE;
此时执行:SELECT test_seq. nextval FROM DUAL;,返回值是1E28,真正应是9999999999999999999999999998,
此时test_seq显示NEXT NUMBER是10000000000000000000000000000。
再执行一次SELECT test_seq. NEXTVAL FROM DUAL;,值还是1E28。但实际值是9999999999999999999999999999,下面例子可以证明,最大值是10的28次方。
再执行一次SELECT test_seq. nextval FROM DUAL;,此时值=1。,

CREATE SEQUENCE test_seq
start with 9999999999999999999999999999
MAXVALUE 10000000000000000000000000000
increment by 1
CYCLE;

SELECT test_seq. nextval FROM DUAL;返回9999999999999999999999999999,

再执行一次SELECT test_seq. nextval FROM DUAL;就会报ORA-08004错误。进一步说明最大值是28个9数字。

4、使用NOMAXVALUE就可以使用无限大值?

CREATE SEQUENCE test_seq
start with 1
NOMAXVALUE
increment by 1
cache 20;

此时test_seq显示MAX VALUE是999999999999999999999999999,27个9数字。

说明即使设置NOMAXVALUE,仍有最大值限制。

结论:

MAXVALUE最大值是28个9,用科学计数法将最大值记做1E28,换句话说,即使设置NOMAXVALUE,也是有这个最大值的。

NOCYCLE是默认值。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C 言語の定数とは何ですか?例を挙げていただけますか? C 言語の定数とは何ですか?例を挙げていただけますか? Aug 28, 2023 pm 10:45 PM

定数は変数とも呼ばれ、一度定義されると、その値はプログラムの実行中に変更されません。したがって、変数を固定値を参照する定数として宣言できます。テキストとも呼ばれます。定数は、Const キーワードを使用して定義する必要があります。構文 C プログラミング言語で使用される定数の構文は次のとおりです - consttypeVariableName; (または) consttype*VariableName; さまざまなタイプの定数 C プログラミング言語で使用されるさまざまなタイプの定数は次のとおりです: 整数定数 - 例: 1,0 、34、4567 浮動小数点定数 - 例: 0.0、156.89、23.456 8 進数および 16 進数の定数 - 例: 16 進数: 0x2a、0xaa.. 8 進数

VSCode および VS C++ IntelliSense が機能しない、またはライブラリを選択しない VSCode および VS C++ IntelliSense が機能しない、またはライブラリを選択しない Feb 29, 2024 pm 01:28 PM

VS Code および Visual Studio C++ IntelliSense は、特に大規模なプロジェクトで作業している場合、ライブラリを選択できない場合があります。 #Include<wx/wx.h> の上にマウスを移動すると、「ソース ファイル 'string.h' を開けません」というエラー メッセージが表示され (「wx/wx.h」に応じて異なります)、オートコンプリート関数が応答しなくなることがあります。この記事では、VSCode および VSC++ IntelliSense が機能しない場合、またはライブラリを抽出できない場合の対処法を説明します。私のインテリセンスが C++ で動作しないのはなぜですか?大きなファイルを扱う場合、IntelliSense が機能しないことがあります。

C++ で配列の最小要素と最大要素を見つける再帰的プログラム C++ で配列の最小要素と最大要素を見つける再帰的プログラム Aug 31, 2023 pm 07:37 PM

整数配列 Arr[] を入力として受け取ります。目標は、再帰的メソッドを使用して配列内の最大要素と最小要素を見つけることです。再帰を使用しているため、長さ = 1 に達するまで配列全体を反復処理し、基本ケースを形成する A[0] を返します。それ以外の場合、現在の要素は現在の最小値または最大値と比較され、その値は後続の要素に対して再帰的に更新されます。この場合のさまざまな入出力シナリオを見てみましょう −入力 −Arr={12,67,99,76,32}; 出力 −配列内の最大値: 99 説明 &mi

Xboxエラーコード8C230002を修正 Xboxエラーコード8C230002を修正 Feb 27, 2024 pm 03:55 PM

エラー コード 8C230002 が原因で、Xbox でコンテンツを購入または視聴できませんか?一部のユーザーは、本体でコンテンツを購入または視聴しようとすると、引き続きこのエラーが発生します。申し訳ありませんが、Xbox サービスに問題があります。後でもう一度お試しください。この問題のヘルプが必要な場合は、www.xbox.com/errorhelp にアクセスしてください。ステータス コード: 8C230002 このエラー コードは通常、サーバーまたはネットワークの一時的な問題によって発生します。ただし、アカウントのプライバシー設定や保護者による制限など、他の理由により、特定のコンテンツの購入または表示が妨げられる場合があります。 Xbox エラー コード 8C230002 を修正する Xbox 本体でコンテンツを視聴または購入しようとしたときにエラー コード 8C が表示された場合

数字の螺旋パターンを出力する C++ プログラム 数字の螺旋パターンを出力する C++ プログラム Sep 05, 2023 pm 06:25 PM

数値をさまざまな形式で表示することは、学習における基本的なコーディング問題の 1 つです。条件文やループ文などのさまざまなコーディング概念。アスタリスクなどの特殊文字を使用して三角形や四角形を印刷するさまざまなプログラムがあります。この記事では、C++ の正方形と同じように、数値をスパイラル形式で出力します。行数 n を入力として受け取り、左上隅から開始して右、次に下、次に左、次に上、そして再び右、というように移動します。数字付きスパイラル パターン 123456724252627282982340414243309223948494431102138474645321120373635343312191817161514

中国東方航空、C919旅客機が間もなく実運用に入ると発表 中国東方航空、C919旅客機が間もなく実運用に入ると発表 May 28, 2023 pm 11:43 PM

5月25日のニュースによると、中国東方航空は性能説明会でC919旅客機の最新の進捗状況を明らかにした。同社によると、COMACと締結したC919購入契約は2021年3月に正式に発効し、最初のC919航空機は2022年末までに引き渡される予定だという。近く正式に実運用が開始される見通しだ。中国東方航空は上海をC919の商業運航の主拠点とし、2022年と2023年に計5機のC919旅客機を導入する計画だ。同社は、今後の導入計画については、運行実態や路線網計画を踏まえて決定するとしている。編集者の理解によれば、C919は世界で完全に独立した知的財産権を有する中国の新世代の単通路本線旅客機であり、国際的に認められた耐空基準に準拠している。すべき

C言語におけるvoidキーワードの機能 C言語におけるvoidキーワードの機能 Feb 19, 2024 pm 11:33 PM

C の void は、空の型、つまり特定の型を持たないデータを表すために使用される特別なキーワードです。 C言語ではvoidは主に以下の3つの場面で使われます。関数の戻り値の型は void です。C 言語では、関数は int、float、char などのさまざまな戻り値の型を持つことができます。ただし、関数が値を返さない場合は、戻り値の型を void に設定できます。これは、関数が実行された後、特定の値を返さないことを意味します。例: voidhelloWorld()

23 年ぶりに C# が TIOBE 2023 年間最優秀プログラミング言語賞を受賞 23 年ぶりに C# が TIOBE 2023 年間最優秀プログラミング言語賞を受賞 Jan 11, 2024 pm 04:45 PM

プログラミング言語の人気を測るベンチマークの 1 つである TIOBE プログラミング コミュニティ インデックスによると、世界中のエンジニア、コース、ベンダー、検索エンジンからデータを収集することによって評価されています。先日、2024年1月のTIOBE Indexが発表され、2023年の公式プログラミング言語ランキングが発表され、C#がTIOBE 2023 Programming Language of the Yearを受賞し、23年ぶりにC#がこの栄誉を獲得しました。 TIOBE の公式プレスリリースによると、C# は 20 年以上トップ 10 内にランクインしていましたが、現在では主要 4 言語に追いつき、1 年間で最大の成長率 (+1.43%) を示したプログラミング言語となっています。この賞を受賞するのは当然のことです。 2 位は Scratch (+0.83%) と Fortran (+0)

See all articles