CREATE TABLE LIKE

CREATE TABLE LIKE语句用于创建一个同Select Query结果相同的表。本文为您介绍CREATE TABLE LIKE的用法。

使用限制

  • Hologres V0.9及以下版本,CREATE TABLE LIKE语句仅支持复制表结构,不支持复制表属性(主键、索引等)。请在Hologres管理控制台的实例详情页查看当前版本。

  • Hologres V0.10版本开始,支持使用CREATE TABLE LIKE语句复制表结构和表属性(主键、索引等),但需要执行以下命令设置GUC。开启GUC后,CREATE TABLE LIKE只支持通过SELECT * FROM <table_name>复制表,不支持其他写法,如SELECT <column_1>, <column_2> FROM <table_name>

    set hg_experimental_enable_create_table_like_properties=true;
  • 使用CREATE TABLE LIKE创建的表不会自动同步源表的数据。

  • 查询语句中的每一个目标列都要有一个不重复的别名,否则建表语句就会生成同列名的语句导致执行报错。示例如下:

    CALL hg_create_table_like('new_table', 'select *, 1 as c, ''a'' as c from src_table');
    ERROR:  column "c" specified more than once
    CONTEXT:  SQL statement "create table new_table (
    "a"     integer,
    "b"     text,
    "c"     integer,
    "c"     text
    );"
    PL/pgSQL function hg_create_table_like(text,text) line 22 at EXECUTE
  • CREATE TABLE LIKE语句支持复制列COMMENT(注释),支持复制Binlog属性,不支持复制表COMMENT和动态分区属性。

普通表

  1. 命令格式

    在Hologres中,普通表CREATE TABLE LIKE的命令格式如下:

    --复制一张普通表,但不能复制表属性
    CALL hg_create_table_like('new_table_name', 'select_query');
    
    --复制一张表并复制表属性
    set hg_experimental_enable_create_table_like_properties=true;--开关参数,session级别
    CALL hg_create_table_like('new_table_name', 'select * from old_table_name');
    说明

    通过调用hg_create_table_like,系统会根据select_query结果的schema创建一个表名为new_table_name的表,但不会插入任何数据。

  2. 参数说明

    • new_table_name:要创建表的表名(不支持创建外部表),只支持固定字符串,不支持字符拼接或函数生成等。

    • select_query:查询的SQL语句串。当SQL中的内容完全为select * from tablename时,CREATE TABLE LIKE会自动同步创建原表的所有属性,包括pk、索引等。如果SQL语句中有较多单引号,可以将$$符号置于SQL语句前后,通过$$query_sql$$改写(推荐使用该用法,操作更简便)自动实现单引号转义,用法如下:

      CALL HG_CREATE_TABLE_LIKE ('table_name', $$query_sql$$ [, 'partition_clause'])
    • old_table_name:需要复制的原表名。

  3. 使用示例

    如在Hologres中存在如下源表:

    BEGIN;
    CREATE TABLE public.src_table (
     "a" int8 NOT NULL,
     "b" text NOT NULL,
    PRIMARY KEY (a)
    );
    CALL SET_TABLE_PROPERTY('public.src_table', 'orientation', 'column');
    CALL SET_TABLE_PROPERTY('public.src_table', 'bitmap_columns', 'b');
    CALL SET_TABLE_PROPERTY('public.src_table', 'dictionary_encoding_columns', 'b:auto');
    CALL SET_TABLE_PROPERTY('public.src_table', 'time_to_live_in_seconds', '3153600000');
    CALL SET_TABLE_PROPERTY('public.src_table', 'distribution_key', 'a');
    CALL SET_TABLE_PROPERTY('public.src_table', 'storage_format', 'segment');
    COMMIT;

    在Hologres中CREATE TABLE LIKE的示例用法如下:

    • 创建一个同源表结构和属性相同的表

      --复制表及属性
      set hg_experimental_enable_create_table_like_properties=true;
      CALL hg_create_table_like('new_table', 'select * from src_table');
    • 创建一个在源表的基础上再增加字段的表

      --新增一个同b一样的字段c
      CALL hg_create_table_like('holo_table_1', $$select *, "b" as c from src_table$$);

分区表

  1. 命令格式

    在Hologres中,分区表的CREATE TABLE LIKE的命令格式如下:

    --复制一张分区表,但不能复制表属性
    CALL hg_create_table_like('new_table_name', 'select_query', 'partition_clause');
  2. 参数说明

    • new_table_name:要创建表的表名(不支持创建外部表),只支持固定字符串,不支持字符拼接或函数生成等。

    • select_query:查询的SQL语句串。当SQL中的内容完全为select * from tablename时,CREATE TABLE LIKE会自动同步创建原表的所有属性,包括pk、索引等。如果SQL语句中有较多单引号,可以将$$符号置于SQL语句前后,通过$$query_sql$$改写(推荐使用该用法,操作更简便)自动实现单引号转义,用法如下:

      CALL HG_CREATE_TABLE_LIKE ('table_name', $$query_sql$$ [, 'partition_clause'])
    • partition_clause:分区相关的语法定义。用于指定分区键,不会自动创建分区子表,需要手动建分区子表。

  3. 使用示例

    如在Hologres中存在如下源表:

    BEGIN;
    CREATE TABLE public.src_table (
     "a" int8 NOT NULL,
     "b" text NOT NULL,
    PRIMARY KEY (a)
    );
    CALL SET_TABLE_PROPERTY('public.src_table', 'orientation', 'column');
    CALL SET_TABLE_PROPERTY('public.src_table', 'bitmap_columns', 'b');
    CALL SET_TABLE_PROPERTY('public.src_table', 'dictionary_encoding_columns', 'b:auto');
    CALL SET_TABLE_PROPERTY('public.src_table', 'time_to_live_in_seconds', '3153600000');
    CALL SET_TABLE_PROPERTY('public.src_table', 'distribution_key', 'a');
    CALL SET_TABLE_PROPERTY('public.src_table', 'storage_format', 'segment');
    COMMIT;

    在Hologres中使用CREATE TABLE LIKE创建一张分区表示例如下:

    • 创建一个分区表

      --新增一个字段ds,并将表设置为以ds为分区的分区表
      CALL hg_create_table_like('new_table', $$select *, "b" as ds from src_table$$, 'partition by list(ds)');
    • 给对应的分区表创建分区子表

      create table new_table_child_20201213 partition of new_table for values in('20201213');--以20201213为分区值
      create table new_table_child_20201214 partition of new_table for values in('20201214');--以20201214为分区值

HoloWeb可视化复制表

HoloWeb提供可视化复制表功能,无需写SQL命令就能复制表,步骤如下。

  1. 进入HoloWeb页面,详情请参见连接HoloWeb并执行查询

  2. HoloWeb页面顶部菜单栏,单击元数据管理

  3. 元数据管理页面左侧的已登录实例列表,鼠标右击要复制的表,选择复制表结构

  4. 复制表结构页签,配置如下参数。复制表结构

    类别

    参数

    说明

    目标位置

    表名

    目标表的表名称,可自定义命名。默认为:源表_copy。

    描述

    对目标表的描述,可选择是否配置。

    模式

    目标表所在的SCHEMA,默认为:public。

    高级选项

    是否同步源表属性

    选择目标表是否同步源表的属性。

    说明

    仅Hologres V0.10及以上版本实例支持同步源表属性,如果您的实例低于V0.10版本,请选择或升级实例。

  5. 单击右上角提交,完成表复制。