0

我正在尝试使用计算的布尔值创建表

CREATE TABLE parts
(
    Id SERIAL PRIMARY KEY,
    Weight INTEGER NOT NULL CHECK(Weight > 0),
    Color VARCHAR(10),
    Price INTEGER NOT NULL CHECK(Price > 0),
    IsCheap BOOL AS (CASE WHEN Price <= 1000 THEN True ELSE False END),
    Name VARCHAR(30)
);

但是得到这个错误

ERROR:  syntax error at or near "AS"
LINE 7:  IsCheap BOOL AS (CASE WHEN Price <= 1000 THEN True ELSE Fal...

我也试过用 BIT 而不是 BOOL - 同样的错误。不知道为什么它不起作用。

4

1 回答 1

4

如果要使用计算列,则需要 Postgres 12(2019-10-03 发布)。

仅靠as自己是不够的。语法需要generated always as ... 按照手册中的说明使用

create table parts
(
  id       serial primary key,
  weight   integer not null check (weight > 0),
  color    varchar(10),
  price    integer not null check (price > 0),
  is_cheap boolean generated always as (price <= 1000) stored,
  name     varchar(30)
);

如果您不使用 Postgres 12,那么我建议创建一个仅包含该属性的视图,price <= 1000 as is_cheap因为该属性的计算非常便宜且无需存储它。

于 2019-10-14T09:11:29.627 回答