ORA-00907: missing right parenthesis

在Oracle中执行SQL语句时,经常我们会遇到"ORA-00907: missing right parenthesis"错误,该错误从字面含义是"缺少右括号"。下面将通过几个实例讲解该错误的出现和解决办法。

在Oracle中执行SQL语句时,经常我们会遇到"ORA-00907: missing right parenthesis"错误,该错误从字面含义是"缺少右括号"。下面将通过几个实例讲解该错误的出现和解决办法。

错误信息如下图:

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别名之前添加一个")"右括号既可。

一个不注意小事情的人,永远不会成功大事业。——戴尔·卡耐基
3 不喜欢
说说我的看法 -
全部评论(
没有评论
关于
本网站属于个人的非赢利性网站,转载的文章遵循原作者的版权声明,如果原文没有版权声明,请来信告知:hxstrive@outlook.com
公众号