2003-03-20 08:02:11 +01:00
|
|
|
---
|
|
|
|
--- test creation of SERIAL column
|
|
|
|
---
|
|
|
|
|
|
|
|
CREATE TABLE serialTest (f1 text, f2 serial);
|
2004-06-10 19:56:03 +02:00
|
|
|
NOTICE: CREATE TABLE will create implicit sequence "serialtest_f2_seq" for serial column "serialtest.f2"
|
2003-03-20 08:02:11 +01:00
|
|
|
|
|
|
|
INSERT INTO serialTest VALUES ('foo');
|
|
|
|
INSERT INTO serialTest VALUES ('bar');
|
|
|
|
INSERT INTO serialTest VALUES ('force', 100);
|
|
|
|
INSERT INTO serialTest VALUES ('wrong', NULL);
|
2003-09-25 08:58:07 +02:00
|
|
|
ERROR: null value in column "f2" violates not-null constraint
|
2003-03-20 08:02:11 +01:00
|
|
|
|
|
|
|
SELECT * FROM serialTest;
|
|
|
|
f1 | f2
|
|
|
|
-------+-----
|
|
|
|
foo | 1
|
|
|
|
bar | 2
|
|
|
|
force | 100
|
|
|
|
(3 rows)
|
|
|
|
|
|
|
|
|
|
|
|
CREATE SEQUENCE sequence_test;
|
|
|
|
|
|
|
|
BEGIN;
|
|
|
|
SELECT nextval('sequence_test');
|
|
|
|
nextval
|
|
|
|
---------
|
|
|
|
1
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
DROP SEQUENCE sequence_test;
|
|
|
|
END;
|
|
|
|
-- renaming sequences
|
|
|
|
CREATE SEQUENCE foo_seq;
|
|
|
|
ALTER TABLE foo_seq RENAME TO foo_seq_new;
|
|
|
|
SELECT * FROM foo_seq_new;
|
|
|
|
sequence_name | last_value | increment_by | max_value | min_value | cache_value | log_cnt | is_cycled | is_called
|
|
|
|
---------------+------------+--------------+---------------------+-----------+-------------+---------+-----------+-----------
|
|
|
|
foo_seq | 1 | 1 | 9223372036854775807 | 1 | 1 | 1 | f | f
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
DROP SEQUENCE foo_seq_new;
|
|
|
|
--
|
|
|
|
-- Alter sequence
|
|
|
|
--
|
|
|
|
CREATE SEQUENCE sequence_test2 START WITH 32;
|
|
|
|
SELECT nextval('sequence_test2');
|
|
|
|
nextval
|
|
|
|
---------
|
|
|
|
32
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
ALTER SEQUENCE sequence_test2 RESTART WITH 16
|
|
|
|
INCREMENT BY 4 MAXVALUE 22 MINVALUE 5 CYCLE;
|
|
|
|
SELECT nextval('sequence_test2');
|
|
|
|
nextval
|
|
|
|
---------
|
|
|
|
16
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
SELECT nextval('sequence_test2');
|
|
|
|
nextval
|
|
|
|
---------
|
|
|
|
20
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
SELECT nextval('sequence_test2');
|
|
|
|
nextval
|
|
|
|
---------
|
|
|
|
5
|
|
|
|
(1 row)
|
|
|
|
|
2003-11-21 23:32:49 +01:00
|
|
|
-- Test comments
|
|
|
|
COMMENT ON SEQUENCE asdf IS 'won''t work';
|
|
|
|
ERROR: relation "asdf" does not exist
|
|
|
|
COMMENT ON SEQUENCE sequence_test2 IS 'will work';
|
|
|
|
COMMENT ON SEQUENCE sequence_test2 IS NULL;
|