A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
#1です。
シーケンスには、CYCLE というパラメータがあるのですね。
早速、これも試してみました。
===========================================================
test=# alter sequence test_id_seq cycle;
ALTER SEQUENCE
test=# insert into test (data)values(10);
INSERT 0 1
test=# select * from test;
id | data
---------------------+------
1 | 1
2 | 2
2147483645 | 3
2147483646 | 4
2147483647 | 5
9223372036854775806 | 7
9223372036854775807 | 8
1 | 10
(8 行)
===========================================================
1 に戻りました。
id にUNIQUE制約付けてなかったので、登録されました。
過去のバージョンではデフォルトで UNIQUE になるようです。
http://www.postgresql.jp/document/pg732doc/user/ …
引用:PostgreSQL 7.3 より前のバージョンでは、serial は UNIQUE を暗黙指定していました。
10を削除して、UNIQUE制約を試します。
===========================================================
test=# delete from test where data=10;
DELETE 1
test=# create unique index id_index on test (id);
CREATE INDEX
test=# insert into test (data)values(11);
ERROR: duplicate key violates unique constraint "id_index"
test=# insert into test (data)values(12);
INSERT 0 1
test=# select * from test;
id | data
---------------------+------
1 | 1
2 | 2
2147483645 | 3
2147483646 | 4
2147483647 | 5
9223372036854775806 | 7
9223372036854775807 | 8
3 | 12
(8 行)
===========================================================
11回目の追加は、UNIQUE制約に引っ掛りエラーです。
12回目の追加は、次の 3 が空いていたので、登録されました。
エラー発生時もカウントは加算されているようですね。
-----------------------------------------------------------
話が、シーケンスの話になってしまいましたが。
serial型 の話に戻して、簡単にまとめてみます。
serial型 を使ったときに、自動で作られるシーケンスでは、
シーケンスの上限に達する前に、integer の上限でエラーが発生。
(これはリトライしても解決しない。)
integer の上限に達する恐れがある場合は、何らかの対処が必要。
シーケンスを修正すれば、integerの範囲で、周回させる事も可能。
しかし、自動で空き番号を選択するような仕組みはない・・・と思います。
繰り返しますが、バージョン8.2.5で確認したので、
他のバージョンや、環境設定により異なると思います。
No.2
- 回答日時:
setvalしない限り1になりません。
シーケンスに定義し
serialをinteger型にしデフォルトnextvalに置き換える事で可能かと思います。
CREATE SEQUENCE tablename_colname_seq MAXVALUE 2XXXXXXXXX CYCLE;
CREATE TABLE tablename (
colname integer DEFAULT nextval('tablename_colname_seq') UNIQUE
);
2になるかどうかはバージョンによるようですが、
UNIQUE制約を付けてduplicateエラーが出る場合リトライする事で対応
可能かと思います。
http://www.postgresql.jp/document/pg732doc/user/ …
No.1
- 回答日時:
PostgreSQL 8.2.5 で確認しました。
まず、下記を参考に。
http://www.j-pal.ne.jp/murai/exp/posgre/no5.html
シーケンスのMAX_VALUEですが、8バイトですね。
9223372036854775807 (7FFF FFFF FFFF FFFF)
つまり、922京3372兆0368億5477万5807。京の単位ですね・・・
まず越える事はないでしょうが、実験してみました。
まず、integer の上限でエラーが出ました。
=================================================================
test=# insert into test (data)values(6);
ERROR: integer out of range
=================================================================
これは、serialが実際はinteger型で作られているからです。
=================================================================
test=# create table test (id serial, data integer);
NOTICE: CREATE TABLE will create implicit sequence "test_id_seq" for serial col
umn "test.id"
CREATE TABLE
test=# \d test;
テーブル "public.test"
カラム | 型 | 修飾語
--------+---------+---------------------------------------------------
id | integer | not null default nextval('test_id_seq'::regclass)
data | integer |
=================================================================
シーケンスの上限はまだ先です。
idのカラムを、numericに変更して、先に進めます。
=================================================================
test=# alter table test alter id type numeric;
ALTER TABLE
test=# \d test
テーブル "public.test"
カラム | 型 | 修飾語
--------+---------+---------------------------------------------------
id | numeric | not null default nextval('test_id_seq'::regclass)
data | integer |
=================================================================
シーケンスの上限でエラーが出ました。
=================================================================
test=# insert into test (data)values(9);
ERROR: nextval: reached maximum value of sequence "test_id_seq" (92233720368547
75807)
=================================================================
因みに実験で追加したのは9件です。
setvalを使って、途中は飛ばしました。(^^;
=================================================================
test=# select * from test;
id | data
---------------------+------
1 | 1
2 | 2
2147483645 | 3
2147483646 | 4
2147483647 | 5
9223372036854775806 | 7
9223372036854775807 | 8
(7 行)
=================================================================
以上、実験終了。
>MAX_VALUEを超えた場合、MIN_VALUE(1)という記載がありますが
今回の実験では、MIN_VALUEには戻りませんでした。
この情報の出所は確かでしょうか?(^^;
(バージョンによる違いかな?・・・)
バージョン 8.2.5では、「エラーになる」が答えだと思います。
setvalを使って、ご利用中のバージョンでも確認してみて下さい。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ExcelからAccessのテーブルに書き込む時に時間がかかる 1 2022/10/14 20:38
- 介護福祉士・ケアマネージャー・社会福祉士 JRの障がい者割についての質問です。 障がい者の方と電車に乗る際、JR九州のホームページを見たのです 1 2022/06/12 23:52
- 物理学 高一の物理基礎に関する質問です。 100m走の記録が10秒であった時、この選手が走っている最中に瞬間 7 2023/05/23 12:43
- 哲学 質問 work は sealioning とどう違うのでしょうか? 1 2022/05/05 04:31
- PostgreSQL DBFluteについて質問です。 環境:PostgreSQL java8 前提:webアプリケーショ 1 2022/07/07 00:49
- Visual Basic(VBA) VBAのトグルボタンでのマクロについて質問です 3 2022/10/10 17:23
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- MySQL 【投稿情報用データベース posts】は必要ないと思います。 1 2022/06/02 21:25
- ドライブ・ストレージ ネットワークHDD(NAS)について教えて下さい。 11 2023/03/08 11:15
- Visual Basic(VBA) 比較して等しくなかったらセルを赤くする 4 2022/07/19 20:11
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
timestamp が空のデータを除い...
-
CSVファイルを読み込んでテーブ...
-
型について
-
SELECT文で足し算をした場合、N...
-
テキストボックスの背景をVB...
-
ACCESS テキストボックスに入...
-
フラグをたてるってどういうこ...
-
SELECT INTOで一度に複数の変数...
-
sqlに記述できない文字
-
【SQL】他テーブルに含まれる値...
-
timestampのデータはどのように...
-
Accessで今日から5日後
-
PostgreSQLのtimestamp型で時間...
-
オラクルのUPDATEで複数テーブル
-
SELECTした結果に行番号を求めたい
-
pandasでsqlite3にテーブル作成...
-
カラム名を変更するには
-
結合したテーブルをSUMしたい
-
エラーを起こす方法
-
既存データをINSERT文にして出...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CSVファイルを読み込んでテーブ...
-
テキストボックスの背景をVB...
-
timestamp が空のデータを除い...
-
SQLSERVER 連番更新について
-
エクセルVBA 10分後にエクセル...
-
SQL SERVERの BULK INSERT
-
SELECT文で足し算をした場合、N...
-
配列データに対する、要素の追...
-
ACCESS テキストボックスに入...
-
データがリストアできない!!
-
エクセルVBEについて
-
平均値のもとめ方
-
時間の比較をしたい
-
1つのドメインを複数のDNSで管...
-
AVR studio6でeepromリードでき...
-
バッチファイルでrenを使用時、...
-
シーケンスを使わずに主キーを...
-
Japanese schools tests
-
date型でのbetweenについて教え...
-
型について
おすすめ情報