Oracle sql - ORA-00907和我的语法不正确

时间:2014-12-10 21:57:14

标签: oracle parentheses ora-00907

我无法弄清楚以下代码的语法问题。当我运行它时,我收到错误

  

ORA-00907:缺少右括号

有人可以指出我的缺点吗?

CREATE OR REPLACE VIEW LATESTAPPLICATIONS AS 
SELECT *
FROM application_history
WHERE entry_time IN
    (SELECT entry_time
    FROM application_history
    GROUP BY application_number; )
ORDER BY entry_number;​

以下是application_history的表格定义。理想情况下,我只想查看带有最新时间戳的应用程序编号。

 CREATE TABLE  "APPLICATION_HISTORY" 
   (    "ENTRY_NUMBER" NUMBER(28,0), 
"APPLICATION_NUMBER" NUMBER(16,0) CONSTRAINT "APP_NUM_NN" NOT NULL ENABLE, 
"ACTIVE" CHAR(1) DEFAULT 0 CONSTRAINT "ACTIVE_NN" NOT NULL ENABLE, 
"STATUS" VARCHAR2(40) DEFAULT 'APPLICATION ENTERED' CONSTRAINT "STATUS_NN" NOT NULL ENABLE, 
"DATE_APPROVED" DATE, 
"DATE_APPLIED" DATE DEFAULT SYSDATE CONSTRAINT "DATE_APPLIED_NN" NOT NULL ENABLE, 
"ENTRY_TIME" TIMESTAMP (6) DEFAULT SYSDATE, 
 CONSTRAINT "ENTRY_NUM_PK" PRIMARY KEY ("ENTRY_NUMBER")
USING INDEX  ENABLE
 )

1 个答案:

答案 0 :(得分:2)

你在最后一行但是有一个分号。 GROUP BY application_number; )删除它,你应该没事。

分号在Oracle中充当查询终止符,因为您在Oracle找不到它之前放置了它。