名称

AddGeometryColumn — 向现有表添加几何列。

概要

text AddGeometryColumn(varchar table_name, varchar column_name, integer srid, varchar type, integer dimension, boolean use_typmod=true);

text AddGeometryColumn(varchar schema_name, varchar table_name, varchar column_name, integer srid, varchar type, integer dimension, boolean use_typmod=true);

text AddGeometryColumn(varchar catalog_name, varchar schema_name, varchar table_name, varchar column_name, integer srid, varchar type, integer dimension, boolean use_typmod=true);

描述

向现有属性表添加几何列。schema_name 是表模式的名称。srid 必须是 SPATIAL_REF_SYS 表中条目的整数值引用。type 必须是与几何类型对应的字符串,例如 'POLYGON' 或 'MULTILINESTRING'。如果 schema_name 不存在(或在当前 search_path 中不可见),或者指定的 SRID、几何类型或维度无效,则会抛出错误。

[Note]

已更改:2.0.0 此函数不再更新 geometry_columns,因为 geometry_columns 是从系统目录读取的视图。默认情况下,它也不创建约束,而是使用 PostgreSQL 的内置类型修饰符行为。因此,例如,使用此函数构建 wgs84 POINT 列现在等同于:ALTER TABLE some_table ADD COLUMN geom geometry(Point,4326);

已更改:2.0.0 如果您需要约束的旧行为,请使用默认的 use_typmod,但将其设置为 false。

[Note]

已更改:2.0.0 视图不再能在 geometry_columns 中手动注册,但是针对几何类型修饰符表几何体构建的视图,并且在不使用包装器函数的情况下使用,将正确地自行注册,因为它们继承了其父表列的类型修饰符行为。使用输出其他几何图形的几何函数的视图需要强制转换为类型修饰符几何图形,以便这些视图几何列可以在 geometry_columns 中正确注册。请参阅第 4.6.3 节,“手动注册几何列”

此方法实现了 OGC 简单要素 SQL 1.1 实现规范。

此函数支持 3D,并且不会删除 z 索引。

此方法支持圆形字符串和曲线。

增强:2.0.0 引入 use_typmod 参数。默认为创建类型修饰符几何列,而不是基于约束的列。

示例

-- Create schema to hold data
CREATE SCHEMA my_schema;
-- Create a new simple PostgreSQL table
CREATE TABLE my_schema.my_spatial_table (id serial);

-- Describing the table shows a simple table with a single "id" column.
postgis=# \d my_schema.my_spatial_table
							 Table "my_schema.my_spatial_table"
 Column |  Type   |                                Modifiers
--------+---------+-------------------------------------------------------------------------
 id     | integer | not null default nextval('my_schema.my_spatial_table_id_seq'::regclass)

-- Add a spatial column to the table
SELECT AddGeometryColumn ('my_schema','my_spatial_table','geom',4326,'POINT',2);

-- Add a point using the old constraint based behavior
SELECT AddGeometryColumn ('my_schema','my_spatial_table','geom_c',4326,'POINT',2, false);

--Add a curvepolygon using old constraint behavior
SELECT AddGeometryColumn ('my_schema','my_spatial_table','geomcp_c',4326,'CURVEPOLYGON',2, false);

-- Describe the table again reveals the addition of a new geometry columns.
\d my_schema.my_spatial_table
                            addgeometrycolumn
-------------------------------------------------------------------------
 my_schema.my_spatial_table.geomcp_c SRID:4326 TYPE:CURVEPOLYGON DIMS:2
(1 row)

                                    Table "my_schema.my_spatial_table"
  Column  |         Type         |                                Modifiers
----------+----------------------+-------------------------------------------------------------------------
 id       | integer              | not null default nextval('my_schema.my_spatial_table_id_seq'::regclass)
 geom     | geometry(Point,4326) |
 geom_c   | geometry             |
 geomcp_c | geometry             |
Check constraints:
    "enforce_dims_geom_c" CHECK (st_ndims(geom_c) = 2)
    "enforce_dims_geomcp_c" CHECK (st_ndims(geomcp_c) = 2)
    "enforce_geotype_geom_c" CHECK (geometrytype(geom_c) = 'POINT'::text OR geom_c IS NULL)
    "enforce_geotype_geomcp_c" CHECK (geometrytype(geomcp_c) = 'CURVEPOLYGON'::text OR geomcp_c IS NULL)
    "enforce_srid_geom_c" CHECK (st_srid(geom_c) = 4326)
    "enforce_srid_geomcp_c" CHECK (st_srid(geomcp_c) = 4326)

-- geometry_columns view also registers the new columns --
SELECT f_geometry_column As col_name, type, srid, coord_dimension As ndims
    FROM geometry_columns
    WHERE f_table_name = 'my_spatial_table' AND f_table_schema = 'my_schema';

 col_name |     type     | srid | ndims
----------+--------------+------+-------
 geom     | Point        | 4326 |     2
 geom_c   | Point        | 4326 |     2
 geomcp_c | CurvePolygon | 4326 |     2