6

给定根模式中的表:

CREATE TABLE user (
    username VARCHAR(50),
    password VARCHAR(50));

Quiz架构中的表:

CREATE TABLE Quiz.Results (
    username VARCHAR(50),
    points INT, 
    FOREIGN KEY (username) REFERENCES user(username));

我无法实际创建外键,因为数据库声称该表user实际上并不存在。我也不能随后添加外键:

ALTER TABLE QUIZ.RESULTS
    ADD FOREIGN KEY (username) REFERENCES user (username) 

当然,这两个表都存储在同一个数据库中。

由于这只是一个家庭作业,我很乐意直接跳过添加外键。但我很好奇这是否确实是 H2 中的一个限制、一个错误,或者它是否按预期工作。

我可以以某种方式引用架构user之外的表吗?quiz

4

2 回答 2

17

如果您引用不同模式中的表,则需要显式设置模式名称。H2 的默认架构名称是public. 例子:

CREATE TABLE user (
    username VARCHAR(50),
    password VARCHAR(50));
create schema quiz;
CREATE TABLE Quiz.Results (
    username VARCHAR(50),
    points INT, 
    FOREIGN KEY (username) 
    REFERENCES public.user(username));

要稍后创建外键约束,请使用:

ALTER TABLE QUIZ.RESULTS
    ADD FOREIGN KEY (username) 
    REFERENCES public.user(username) ;
于 2013-05-07T14:20:43.473 回答
0

是的,很有可能。您需要为两个表使用相应的模式名称。

假设您的默认架构名称是,DefaultSchema那么您的查询将是

ALTER TABLE QUIZ.RESULTS
ADD FOREIGN KEY (username) REFERENCES DefaultSchema.user (username) 
于 2013-05-07T14:21:18.057 回答