H2数据库:从外键约束引用根模式中的表

Iva*_*ica 6 java sql database h2

给定根模式中的表:

CREATE TABLE user (
    username VARCHAR(50),
    password VARCHAR(50));
Run Code Online (Sandbox Code Playgroud)

Quiz架构中的表:

CREATE TABLE Quiz.Results (
    username VARCHAR(50),
    points INT, 
    FOREIGN KEY (username) REFERENCES user(username));
Run Code Online (Sandbox Code Playgroud)

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

ALTER TABLE QUIZ.RESULTS
    ADD FOREIGN KEY (username) REFERENCES user (username) 
Run Code Online (Sandbox Code Playgroud)

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

由于这只是一个功课,我很乐意简单地跳过添加外键.但我很好奇这是否确实是H2中的限制,一个错误,或者它是否按预期工作.

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

Tho*_*ler 15

如果引用不同模式中的表,则需要显式设置模式名称.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));
Run Code Online (Sandbox Code Playgroud)

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

ALTER TABLE QUIZ.RESULTS
    ADD FOREIGN KEY (username) 
    REFERENCES public.user(username) ;
Run Code Online (Sandbox Code Playgroud)