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 不喜欢
说说我的看法 -
全部评论(
没有评论
关于
本网站专注于 Java、数据库(MySQL、Oracle)、Linux、软件架构及大数据等多领域技术知识分享。涵盖丰富的原创与精选技术文章,助力技术传播与交流。无论是技术新手渴望入门,还是资深开发者寻求进阶,这里都能为您提供深度见解与实用经验,让复杂编码变得轻松易懂,携手共赴技术提升新高度。如有侵权,请来信告知:hxstrive@outlook.com
公众号