HSQLDB错误:意外的标记:外国

问题描述:

我有以下SQL我在我的本地HSQLDB 2.3.2数据库运行:HSQLDB错误:意外的标记:外国

CREATE TABLE IF NOT EXISTS countries (
    country_id    INTEGER GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1) NOT NULL PRIMARY KEY, 
    country_version   INTEGER NOT NULL, 
    country_name   NVARCHAR(100) NOT NULL, 
    country_label   NVARCHAR(100) NOT NULL, 
    country_description  NVARCHAR(500) NOT NULL 
    country_code   NVARCHAR(10) NOT NULL, 

    CONSTRAINT uc_countries UNIQUE (country_id, country_version, country_label, country_description, country_code) 
); 

CREATE TABLE IF NOT EXISTS states (
    state_id    INTEGER GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1) NOT NULL PRIMARY KEY, 
    state_version   INTEGER NOT NULL 
    state_name    NVARCHAR(100) NOT NULL, 
    state_label    NVARCHAR(100) NOT NULL, 
    state_description  NVARCHAR(500) NOT NULL, 
    country_id    INT NOT NULL, 

    FOREIGN KEY (country_id) REFERENCES countries(country_id), 
    CONSTRAINT uc_states UNIQUE (state_id, state_version, state_label, state_description, country_id) 
); 

当我运行此我得到:

Error: unexpected token: FOREIGN 
SQLState: 42581 
ErrorCode: -5581 

是什么去这里,我能做些什么来解决它?

+1

为什么没有解释的downvote?如果这是一个骗局,请给我看看这个问题!否则,这是一个[SSCCE](http://sscce.org/),显示努力/研究,并包含诊断/排除故障所需的一切。 – IAmYourFaja 2014-12-07 10:43:48

+1

我没有downvote你,但我认为这是一个很好的问题,所以我upvoted它。 – april4181 2014-12-10 16:15:10

+2

如果分别执行每个语句,是否还会出现此错误?这可能是由于它符合的方式。 – april4181 2014-12-10 16:19:44

INT NOT NULLINTEGER NOT NULL之间的差异?因为您已经通过两者定义了country_id字段。

另外,如果你在顶端插入SET REFERENTIAL_INTEGRITY FALSE;,你还收到此错误?

+1

Ughhhhh,我不能相信多久我在那个一直盯着,并已俯瞰它。 'INT'无效,它必须是'INTEGER'。赏金和接受的答案奖励!谢谢! – IAmYourFaja 2014-12-10 20:02:26