5

我正在尝试在 Oracle 11g 中执行此脚本并收到以下错误,我不知道我在哪里遗漏了括号或者是什么错误请帮助我解决这个问题。

脚本:

CREATE TABLE User_Role ( 
  user_role_id INT  NOT NULL  , 
  Users_user_id INT  FOREIGN KEY REFERENCES Users(user_id), 
  User_Types_user_type VARCHAR(20) FOREIGN KEY REFERENCES User_Types(user_type),  
  PRIMARY KEY(user_role_id) 
)

错误:

ORA-00907: 缺少右括号

4

4 回答 4

7

删除FOREIGN KEY子句。重写你的CREATE TABLE陈述如下:

CREATE TABLE User_Role ( 
      user_role_id         INT  NOT NULL  , 
      Users_user_id        INT  REFERENCES Users(user_id), 
      User_Types_user_type VARCHAR(20) REFERENCES User_Types(user_type),  
      PRIMARY KEY(user_role_id) 
    )

在这种情况下,约束名称将由 Oracle 生成。如果你想给他们更有意义的名字,你可以写你的create table声明如下:

  CREATE TABLE User_Role1 ( 
      user_role_id         INT  NOT NULL  , 
      Users_user_id        INT  , 
      User_Types_user_type VARCHAR(20) ,  
      constraint PK_YourTable PRIMARY KEY(user_role_id), 
      constraint FK_Table_1 foreign key(Users_user_id) REFERENCES Users(user_id),
      constraint FK_Table_2 foreign key(User_Types_user_type) REFERENCES User_Types(user_type)
    )
于 2012-11-12T19:47:02.077 回答
0

我认为您需要先定义列,然后以与添加FOREIGN KEY约束相同的方式添加PRIMARY KEY约束,如下所示:

    CREATE TABLE User_Role ( 
       user_role_id INT  NOT NULL  , 
       Users_user_id INT, 
       User_Types_user_type VARCHAR(20),
       FOREIGN KEY (Users_user_id) REFERENCES Users(user_id),
       FOREIGN KEY (User_Types_user_type) REFERENCES User_Types(user_type), 
       PRIMARY KEY(user_role_id) 
     )
于 2012-11-12T19:50:44.097 回答
0

删除 int 的大小并重新编译

例子 :-

integer (20) not null
integer not null
User_Types_user_type VARCHAR(20),
User_Types_user_type VARCHAR,
于 2013-08-31T08:30:16.253 回答
0

可以指定内联外键,您只需要删除foreign key关键字:

CREATE TABLE User_Role 
(
  user_role_id           INT NOT NULL  , 
  Users_user_id          INT         REFERENCES Users, 
  User_Types_user_type   VARCHAR(20) REFERENCES User_Types,  
  PRIMARY KEY(user_role_id) 
);

SQLFiddle 示例:http ://sqlfiddle.com/#!4/4ca9f/1

在“引用”部分列出主键列是可选的。如果你愿意,你也可以写REFERENCES Users(user_id)

这种格式还有一个缺点是约束名称将由 Oracle 生成(具有无意义的名称)。为了能够正确地为外键指定约束名称,您需要使用已接受答案中的语法。

于 2013-08-31T08:58:54.173 回答