首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Postgres SQL约束字符类型

Postgres SQL约束字符类型
EN

Stack Overflow用户
提问于 2015-06-15 12:21:15
回答 2查看 1.9K关注 0票数 1

我在Postgres有一个表格定义。我想向字符数据类型为只有3个允许值的列添加一个约束:

代码语言:javascript
复制
CREATE TABLE my_table
(
  id character varying(255) NOT NULL,
  uid character varying(255) NOT NULL,
  my_text text NOT NULL,
  is_enabled boolean NOT NULL
);

因此,我希望my_text列只包含'A‘、'B’或'C‘作为值。

我在哪里能找到关于这个的一些文件?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-06-15 12:26:22

使用check约束:

代码语言:javascript
复制
CREATE TABLE my_table
(
  id character varying(255) NOT NULL,
  uid character varying(255) NOT NULL,
  my_text text NOT NULL,
  is_enabled boolean NOT NULL,
  constraint check_allowed check (my_text in ('A', 'B', 'C'))
);

手册中的更多细节:http://www.postgresql.org/docs/current/static/ddl-constraints.html#DDL-CONSTRAINTS-CHECK-CONSTRAINTS

票数 4
EN

Stack Overflow用户

发布于 2015-06-15 12:34:07

如果您想在不改变条件的情况下添加字符:

代码语言:javascript
复制
CREATE TABLE my_ref
(
  my_value varying(1) PRIMARY KEY
)

INSERT INTO my_ref VALUES( 'A' );
INSERT INTO my_ref VALUES( 'B' );
INSERT INTO my_ref VALUES( 'C' );

CREATE TABLE my_table
(
  id character varying(255) NOT NULL,
  uid character varying(255) NOT NULL,
  my_text text NOT NULL,
  is_enabled boolean NOT NULL,
  constraint check_allowed FOREIGN KEY( my_text ) REFERENCES my_ref( my_value )
);

您将无法在my_text中添加不在my_ref表中的值。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30845055

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档