我正在使用 PostgreSQL 数据库,并使用枚举类型的数组作为其中一列。
CREATE TYPE my_type_enum AS ENUM ('value1', 'value2', 'value3');
ALTER TABLE "my_table" ADD COLUMN IF NOT EXISTS "my_column" my_type_enum ARRAY;
The enum
让我只添加它包含的有效值,但我也可以添加null
其元素。
所以,为了防止保存null
元素到数据库,我在应用程序中添加了一个过滤器,但我想知道PostgreSQL中是否有一个定义不允许添加null
元素到array
?
附:我看见here https://stackoverflow.com/questions/45576834/declare-a-column-of-type-not-null-string-array-in-postgresql建议添加函数作为列定义的一部分,但这不是我要求的。
您可以添加检查约束来防止元素具有 NULL 值。
alter table my_table
add constraint no_null_element
check (cardinality(my_column) = cardinality(array_remove(my_column, null)));
更干净的解决方案是与外键列建立规范化的一对多关系,定义为not null
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)