我在 SQL 中对电气原理图建模时遇到了一些麻烦。我想捕获的结构是
part ??????????? pin
? ?
part_inst ?????? pin_inst
Run Code Online (Sandbox Code Playgroud)
其中“inst”是“instance”的缩写。
例如,我可能part
将 LM358 运算放大器pin
用作 1OUT、1IN-、1IN+、GND、2IN+、2IN-、2OUT 和 V CC。然后我可能会将这部分放在原理图上,创建 apart_inst
和 8
pin_inst
s。
忽略数据字段,我对模式的最初尝试是
create table parts (
part_id bigserial primary key
);
create table pins (
pin_id bigserial primary key,
part_id bigint not null references parts
);
create table part_insts (
part_inst_id bigserial primary key,
part_id bigint not null references parts
);
create table pin_insts (
pin_inst_id bigserial primary key,
part_inst_id bigint …
Run Code Online (Sandbox Code Playgroud) postgresql foreign-key database-design referential-integrity polymorphic-associations
是否可以在 Postgres 中创建一个约束来运行函数,但前提是特定列发生更改?
现在,我有这个:
ALTER TABLE public.employee
ADD CONSTRAINT pin_is_unique_in_company CHECK
(fn_pin_is_unique_in_company(id, company_id, pin));
Run Code Online (Sandbox Code Playgroud)
我只希望在 pin 列被修改时运行。
以下操作始终受到并行限制。
- 扫描公共表表达式 (CTE)。
- 临时表的扫描。
- ...
[...] 同样,
PARALLEL RESTRICTED
如果函数访问临时表、客户端连接状态、游标、准备好的语句或系统无法跨工作器同步的其他后端本地状态,则必须标记它们。例如,由于最后一个原因setseed
而random
受到并行限制。
没有提到 CTE。现在我不确定我是否可以PARALLEL SAFE
用于包含 CTE 的函数。对我来说只有PARALLEL RESTRICTED
.
上下文:我必须确定现有用户定义函数的最佳标签。该设置是自 Postgres 9.6 以来的新设置,并且可以对性能产生巨大影响,因为涉及PARALLEL SAFE
并行工作人员不会执行的功能的操作,PARALLEL RESTRICTED
只能由领导者执行。(并PARALLEL USAFE
完全禁用并行性。)
我在 pgsql-general 上发布了一个相关的问题。