给定根模式中的表:
CREATE TABLE user ( username VARCHAR(50),password VARCHAR(50));
和测验架构中的表格:
CREATE TABLE Quiz.Results ( username VARCHAR(50),points INT,FOREIGN KEY (username) REFERENCES user(username));
我无法实际创建外键,因为数据库声称表用户实际上并不存在.我随后也不能添加外键:
ALTER TABLE QUIZ.RESULTS ADD FOREIGN KEY (username) REFERENCES user (username)
当然,这两个表都存储在同一个数据库中.
由于这只是一个功课,我很乐意简单地跳过添加外键.但我很好奇这是否确实是H2中的限制,一个错误,或者它是否按预期工作.
我可以以某种方式引用测验架构之外的表用户吗?
解决方法
如果引用不同模式中的表,则需要显式设置模式名称. H2的默认架构名称是public.例:
CREATE TABLE user ( username VARCHAR(50),password VARCHAR(50)); create schema quiz; CREATE TABLE Quiz.Results ( username VARCHAR(50),FOREIGN KEY (username) REFERENCES public.user(username));
要在以后创建外键约束,请使用:
ALTER TABLE QUIZ.RESULTS ADD FOREIGN KEY (username) REFERENCES public.user(username) ;