Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/73.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在postgreSQL中使用表继承的最佳方法是什么?_Sql_Postgresql - Fatal编程技术网

在postgreSQL中使用表继承的最佳方法是什么?

在postgreSQL中使用表继承的最佳方法是什么?,sql,postgresql,Sql,Postgresql,我想在我的数据库(PostgreSQL)中使用继承,所以我写了这段代码,但最后我发现在PostgreSQL中有继承 CREATE SEQUENCE public.user_account_id_seq; CREATE TABLE public.user_account ( id BIGINT NOT NULL DEFAULT nextval('public.user_account_id_seq'), login VARCHAR(5

我想在我的数据库(PostgreSQL)中使用继承,所以我写了这段代码,但最后我发现在PostgreSQL中有继承

CREATE SEQUENCE public.user_account_id_seq;
CREATE TABLE public.user_account (
                id BIGINT NOT NULL DEFAULT nextval('public.user_account_id_seq'),
                login VARCHAR(50) NOT NULL,
                f_name VARCHAR(50),
                l_name VARCHAR(50),
                email VARCHAR(50) ,
                CONSTRAINT user_account_pk PRIMARY KEY (id)
);

CREATE SEQUENCE public.simple_user_account_id_seq;
CREATE TABLE public.simple_user_account (
                id BIGINT NOT NULL DEFAULT nextval('public.simple_user_account_id_seq'),
                CONSTRAINT simple_user_account_pk PRIMARY KEY (id)
);

CREATE SEQUENCE public.supervisor_account_id_seq;
CREATE TABLE public.supervisor_account (
                id BIGINT NOT NULL DEFAULT nextval('public.supervisor_account_id_seq'),
                CONSTRAINT supervisor_account_pk PRIMARY KEY (id)
);


或者我使用postgreSQL的继承,你不能有全局唯一的约束。如果你不介意的话,你可以使用该功能。

它与hibernate(在ORM中)兼容吗?但是它不适用于hibernate我发现这似乎是可信的,像继承这样的非标准功能不适用于hibernate(你在问题中没有提到)。“ORM”和“works”之间的联系通常是松散的。您可能会得到一个非常简单的数据模型。这就是我的想法。我会接受您的回答。谢谢
ALTER TABLE public.simple_user_account ADD CONSTRAINT simple_user_account_fk
FOREIGN KEY (id)
REFERENCES public.user_account (id)
ON DELETE CASCADE
ON UPDATE NO ACTION
NOT DEFERRABLE;

ALTER TABLE public.supervisor_account ADD CONSTRAINT supervisor_account_fk
FOREIGN KEY (id)
REFERENCES public.user_account (id)
ON DELETE CASCADE
ON UPDATE NO ACTION
NOT DEFERRABLE;