sql - ORA-00907: 缺少右括号

标签 sql oracle ora-00907

CREATE TABLE Persons (
  P_Id int NOT NULL,
  LastName varchar(255) NOT NULL,
  FirstName varchar(255),
  PRIMARY KEY (P_Id)
)

CREATE TABLE Orders (
  O_Id int NOT NULL PRIMARY KEY,
  OrderNo int NOT NULL,
  P_Id int FOREIGN KEY REFERENCES Persons(P_Id)
)

创建表订单时出现错误:

ORA-00907: missing right parenthesis

最佳答案

如果您要定义与列定义内联的外键,则不应指定 FOREIGN KEY。从定义中删除它。

尝试这个:

CREATE TABLE Orders 
( 
  O_Id int NOT NULL PRIMARY KEY, 
  OrderNo int NOT NULL,
  P_Id int REFERENCES Persons(P_Id)
)

关于sql - ORA-00907: 缺少右括号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6819869/

相关文章:

c# - Oracle 更新表中的重复行

sql - 由于 CASE 原因,行无法正确组合?

sql - 包含计数不工作的内部连接的存储过程

php - 如何在 win7 x64 上使用带有 php (xampp) 的 oracle 客户端 11.2

mysql - 从 Oracle 到 MySQL 的数据传输

sql - 为什么 Oracle 认为我缺少右括号?

sql - oracle中如何使用级联

SQL 服务器 : impact of column collation on T-SQL instructions

java - (Cloudant DB Java API) 执行类似操作 Select Distinct with WHERE 子句