加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-15 00:00:13 所属栏目:Java 来源:网络整理
导读:给定根模式中的表: CREATE TABLE user ( username VARCHAR(50),password VARCHAR(50)); 和测验架构中的表格: CREATE TABLE Quiz.Results ( username VARCHAR(50),points INT,FOREIGN KEY (username) REFERENCES user(username)); 我无法实际创建外键,因为
给定根模式中的表:
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) ;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读