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キーワードを削除するだけです。

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 に答える
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 に答える