st 25. 3. 2020 v 13:53 odesílatel Prabhat Sahu <
prabhat.s...@enterprisedb.com> napsal:

> Hi All,
>
> Please check the behavior of GTT  having column with "SERIAL" datatype and
> column with default value as "SEQUENCE" as below:
>
>
> *Session1:*postgres=# create sequence gtt_c3_seq;
> CREATE SEQUENCE
> postgres=# create global temporary table gtt(c1 int, c2 serial, c3 int
> default nextval('gtt_c3_seq') not null) on commit preserve rows;
> CREATE TABLE
>
> -- Structure of column c2 and c3 are similar:
> postgres=# \d+ gtt
>                                                 Table "public.gtt"
>  Column |  Type   | Collation | Nullable |             Default
> | Storage | Stats target | Description
>
> --------+---------+-----------+----------+---------------------------------+---------+--------------+-------------
>  c1     | integer |           |          |
> | plain   |              |
>  c2     | integer |           | not null | nextval('gtt_c2_seq'::regclass)
> | plain   |              |
>  c3     | integer |           | not null | nextval('gtt_c3_seq'::regclass)
> | plain   |              |
> Access method: heap
> Options: on_commit_delete_rows=false
>
> postgres=# insert into gtt select generate_series(1,3);
> INSERT 0 3
> postgres=# select * from gtt;
>  c1 | c2 | c3
> ----+----+----
>   1 |  1 |  1
>   2 |  2 |  2
>   3 |  3 |  3
> (3 rows)
>
>
> *Session2:*postgres=# insert into gtt select generate_series(1,3);
> INSERT 0 3
> postgres=# select * from gtt;
>  c1 | c2 | c3
> ----+----+----
>   1 |  1 |  4
>   2 |  2 |  5
>   3 |  3 |  6
> (3 rows)
>
> Kindly let me know, Is this behavior expected?
>

It is interesting side effect - theoretically it  is not important, because
sequence ensure just unique values - so values are not important.

You created classic shared sequence so the behave is correct and expected.

Pavel


> --
>
> With Regards,
> Prabhat Kumar Sahu
> EnterpriseDB: http://www.enterprisedb.com
>

Reply via email to