回复: [bug report] About create table like feature's bug - Mailing list pgsql-bugs
| From | dengkai |
|---|---|
| Subject | 回复: [bug report] About create table like feature's bug |
| Date | |
| Msg-id | tencent_50F72E35C952D945729B4E55741D1790EC08@qq.com Whole thread Raw |
| In response to | Re: [bug report] About create table like feature's bug (Laurenz Albe <laurenz.albe@cybertec.at>) |
| List | pgsql-bugs |
ok, thanks for your reply.
------------------ 原始邮件 ------------------
发件人: "Laurenz Albe" <laurenz.albe@cybertec.at>;
发送时间: 2025年10月31日(星期五) 下午4:50
收件人: "dengkai"<784523565@qq.com>;"pgsql-bugs"<pgsql-bugs@lists.postgresql.org>;
主题: Re: [bug report] About create table like feature's bug
> When I use 'create table like' command to create a table with 'including indexes' options, database return
> an unexpected result. Look at the following sql statement.
>
> postgres=# create table t1(c1 int, c2 char(10));
> CREATE TABLE
> postgres=# create index idx1 on t1(c1);
> CREATE INDEX
> postgres=# \d+ t1
> Table "public.t1"
> Column | Type | Collation | Nullable | Default | Storage | Compression | Stats target | Description
> --------+---------------+-----------+----------+---------+----------+-------------+--------------+-------------
> c1 | integer | | | | plain | | |
> c2 | character(10) | | | | extended | | |
> Indexes:
> "idx1" btree (c1)
> Access method: heap
>
> postgres=# create table t2(like t1 including indexes);
> CREATE TABLE
> postgres=# \d+ t2
> Table "public.t2"
> Column | Type | Collation | Nullable | Default | Storage | Compression | Stats target | Description
> --------+---------------+-----------+----------+---------+----------+-------------+--------------+-------------
> c1 | integer | | | | plain | | |
> c2 | character(10) | | | | extended | | |
> Indexes:
> "t2_c1_idx" btree (c1)
> Access method: heap
>
> postgres=# select version();
> version
> ------------------------------------------------------------------------------------------------------------
> PostgreSQL 16devel on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-44), 64-bit
> (1 row)
That's an alpha or beta version of an old release. Bad choice.
> I did not use 'including storage' option in 'create table like' statement, but there is an extended attribute on t2.c2.
> It seems that the 'including storage' option is not effective, the default behavior of database is to bring the storage
> attribute from original table columns to the new table.
>
> I found this phenomenon on pg15.5 version. And it should also be present on pg18. Is this a bug?
No, that is not a bug. EXTENDED is the default storage method.
See this example:
test=> CREATE TABLE t (c text STORAGE EXTERNAL);
CREATE TABLE
test=> \d+ t
Table "laurenz.t"
Column │ Type │ Collation │ Nullable │ Default │ Storage │ Compression │ Stats target │ Description
════════╪══════╪═══════════╪══════════╪═════════╪══════════╪═════════════╪══════════════╪═════════════
c │ text │ │ │ │ external │ │ │
Access method: heap
test=> CREATE TABLE t1 (LIKE t);
CREATE TABLE
test=> \d+ t1
Table "laurenz.t1"
Column │ Type │ Collation │ Nullable │ Default │ Storage │ Compression │ Stats target │ Description
════════╪══════╪═══════════╪══════════╪═════════╪══════════╪═════════════╪══════════════╪═════════════
c │ text │ │ │ │ extended │ │ │
Access method: heap
Yours,
Laurenz Albe
pgsql-bugs by date: