从 2025 年 11 月 1 日起,Amazon Redshift 将不再支持创建新的 Python UDF。如果您想要使用 Python UDF,请在该日期之前创建 UDF。现有的 Python UDF 将继续正常运行。有关更多信息,请参阅博客文章
SHOW TABLE
显示表的定义,包括表属性、表约束、列属性、列排序规则和列约束。您可以使用 SHOW TABLE 语句的输出来重新创建表。
有关表创建的更多信息,请参阅CREATE TABLE。
语法
SHOW TABLE [schema_name.]table_name
参数
- schema_name
-
(可选)相关 schema 的名称。
- table_name
-
要显示的表的名称。
示例
以下是表 sales 的 SHOW TABLE 输出示例。
show table sales;
CREATE TABLE public.sales ( salesid integer NOT NULL ENCODE az64, listid integer NOT NULL ENCODE az64 distkey, sellerid integer NOT NULL ENCODE az64, buyerid integer NOT NULL ENCODE az64, eventid integer NOT NULL ENCODE az64, dateid smallint NOT NULL, qtysold smallint NOT NULL ENCODE az64, pricepaid numeric(8,2) ENCODE az64, commission numeric(8,2) ENCODE az64, saletime timestamp without time zone ENCODE az64 ) DISTSTYLE KEY SORTKEY ( dateid );
以下是 schema public 中的表 category 的 SHOW TABLE 输出示例。数据库的排序规则为 CASE_SENSITIVE。
show table public.category;
CREATE TABLE public.category ( catid smallint NOT NULL distkey, catgroup character varying(10) ENCODE lzo COLLATE case_sensitive, catname character varying(10) ENCODE lzo COLLATE case_sensitive, catdesc character varying(50) ENCODE lzo COLLATE case_sensitive ) DISTSTYLE KEY SORTKEY ( catid );
以下示例将使用主键创建表 foo。
create table foo(a int PRIMARY KEY, b int);
SHOW TABLE 结果将显示 create 语句,以及 foo 表的所有属性。
show table foo;
CREATE TABLE public.foo ( a integer NOT NULL ENCODE az64, b integer ENCODE az64, PRIMARY KEY (a) ) DISTSTYLE AUTO;
在此示例中,我们创建了一个表,其中列 a 继承数据库的默认 CASE_SENSITIVE 排序规则,而列 b 和 c 则显式设置为 CASE_INSENSITIVE 排序规则。
CREATE TABLE public.foo ( a CHAR, b VARCHAR(10) COLLATE CASE_INSENSITIVE, c SUPER COLLATE CASE_INSENSITIVE );
SHOW TABLE 结果将显示 create 语句,以及 foo 表的所有属性。
show table public.foo;
CREATE TABLE public.foo ( a character(1) ENCODE lzo COLLATE case_sensitive, b character varying(10) ENCODE lzo COLLATE case_insensitive, c super COLLATE case_insensitive ) DISTSTYLE AUTO;