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
是什么去这里,我能做些什么来解决它?
答
有INT NOT NULL
和INTEGER NOT NULL
之间的差异?因为您已经通过两者定义了country_id
字段。
另外,如果你在顶端插入SET REFERENTIAL_INTEGRITY FALSE;
,你还收到此错误?
+1
Ughhhhh,我不能相信多久我在那个一直盯着,并已俯瞰它。 'INT'无效,它必须是'INTEGER'。赏金和接受的答案奖励!谢谢! – IAmYourFaja 2014-12-10 20:02:26
为什么没有解释的downvote?如果这是一个骗局,请给我看看这个问题!否则,这是一个[SSCCE](http://sscce.org/),显示努力/研究,并包含诊断/排除故障所需的一切。 – IAmYourFaja 2014-12-07 10:43:48
我没有downvote你,但我认为这是一个很好的问题,所以我upvoted它。 – april4181 2014-12-10 16:15:10
如果分别执行每个语句,是否还会出现此错误?这可能是由于它符合的方式。 – april4181 2014-12-10 16:19:44