给出根模式中的表:
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
吗?
答案 0 :(得分: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));
要稍后创建外键约束,请使用:
ALTER TABLE QUIZ.RESULTS
ADD FOREIGN KEY (username)
REFERENCES public.user(username) ;
答案 1 :(得分:0)
是的,非常可能。您需要为两个表使用相应的Schema名称。
假设您的defualt架构名称为DefaultSchema
,那么您的查询将为
ALTER TABLE QUIZ.RESULTS
ADD FOREIGN KEY (username) REFERENCES DefaultSchema.user (username)