在Oracle中执行SQL语句时,经常我们会遇到"ORA-00907: missing right parenthesis"错误,该错误从字面含义是"缺少右括号"。下面将通过几个实例讲解该错误的出现和解决办法。
错误信息如下图:
场景1:在执行create table语句时,给不该指定长度的类型指定了长度。如下:
CREATE TABLE test( id int(10) PRIMARY KEY, name varchar2(200) );
解决办法:将int后面的(10)去除掉
场景2:在定义字段默认值时,将关键字default 放在默认值后面,如下:
CREATE TABLE test( id int PRIMARY KEY, name varchar2(200) '0' default );
解决办法:将name varchar2(200) '0' default 改为 name varchar2(200) default '0'
场景3:在编写SELECT语句时,忽略掉了某个右括号,这在SQL语句很复杂的时候容易犯。如下:
SELECT * FROM ( SELECT a.EMPNO, a.ENAME, b.DEPTNO, b.DNAME, b.LOC FROM EMP a JOIN DEPT b ON a.DEPTNO=b.DEPTNO AND ( b.DNAME LIKE '%SA%' OR b.loc='DALLAS' ) t;
解决办法:在t别名之前添加一个")"右括号既可。