ORA-00907: 缺失右括号问题整理解决
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了ORA-00907: 缺失右括号问题整理解决,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2590字,纯文字阅读大概需要4分钟。
内容图文
ORA-00907: 缺失右括号
前言
近期在开发过程中使用oracle数据库,在程序中进行查询数据时遇到了“ORA-00907: 缺失右括号”的问题。可是假设直接把sql语句直接在数据库或PL/SQL中运行时。却又能够正常查询,为了解决问题,折腾了半天。查找了一些资料,所以就对各种导致出现“缺失右括号”的情况进行了整理总结。
行文例如以下。
1 union all中order by 导致缺失右括号
在有union all的子查询中使用了order by,会导致缺失右括号的错误,其实在有union all的子查询中根本不是必需进行排序,由于联合之后又组成了一个新的集合,之前的排序对新集合而言没什么用,直接查询联合之后的新集合然后再进行排序就可以。
示比例如以下:
select * from
(
select COLUMN_A,COLUMN_B
from TABLE_EXAMPLE_A
order by COLUMN_A
union all
select COLUMN_A,COLUMN_B
from TABLE_EXAMPLE_B
order by COLUMN_A
) A;
解决方式例如以下:
select * from
(
select COLUMN_A,COLUMN_B
from TABLE_EXAMPLE_A
union all
select COLUMN_A,COLUMN_B
from TABLE_EXAMPLE_B
) A;
order by COLUMN_A
2. in (子查询)的使用方法中。子查询不能使用order by!
此种情况跟1中描绘的有些相似,首先在in(子查询)使用方法使用order by 会报错。其次。子查询里用order by,纯属多此一举,子查询的目的,仅仅是找出合适的数据。假设须要排序。在外边排就可以。
示比例如以下:
Select * fromTABEL_EXAMPLE where ID in(select ID from TABLE_EXAMPLE where ID>500 oder byID DESC)
解决方式例如以下:
Select * fromTABEL_EXAMPLE where ID in(select ID from TABLE_EXAMPLE where ID>500)oder by ID DESC
3. 创建表时,提示缺失又括号
3.1 创建表时keyword顺序错
示比例如以下:
CREATE TABLE T_EXAMPLE(
id serial primary key,
t_id int not null default 0
)
解决方式例如以下:
CREATE TABLE T_EXAMPLE(
id serial primary key,
t_id int default 0 not null
)
3.2 创建表时表中字段有keyword
示比例如以下:
CREATE TBALET_EXAMPLE
(
id number(18,0) not null,
desc varchar(45) not null
)
解决方式例如以下:
给相应的keyword加上双引號
CREATE TBALET_EXAMPLE
(
id number(18,0) not null,
“desc” varchar(45) not null
)
3.3 创建表时未对表中的字段设置长度
示比例如以下:
CREATE TABELT_EXAMPLE
(
id bigint NOT NULL PRIMARY KEY,
name varchar NOT NULL
)
解决方式例如以下:
CREATE TABELT_EXAMPLE
(
id bigint NOT NULL PRIMARY KEY,
name varchar(200) NOT NULL
)
3.4 创建主外键约束时外键类型跟主键类型不全然一致
主外键类型不全然一致时也会报缺失右括号的错误
4. SQL查询时发生缺失右括号错误
在查询时引发缺失右括号错误的原因大多数在于查询语句中有关于日期的转化、过滤。非常多时候都是由于关于日期类型的转化少了单引號。
示比例如以下:
SELECT * FROM T_EXAMPLE Where T_DATE in(2015-01-20 22:37)
解决方式例如以下:
SELECT * FROM T_EXAMPLE Where T_DATE in(‘2015-01-20 22:37‘)
另一种情况就是在where过滤中进行时间的转化时。有时候在sql/plus中直接运行没问题,可是在程序中却会出现错误。
示比例如以下:
SELECT * FROM T_EXAMPLE Where
ID in(select ID From T_EXAMPLE_B where D_DATE>=TO_DATE(‘2015-01-20’,’yyyy-mm-dd’))
该语句在数据库直接运行是没问题的,可是在程序中运行传入日期參数时有时会报缺失右括号的错误,为了解决问题。我们能够改变传入的日期參数的格式,例如以下:
SELECT * FROM T_EXAMPLE Where
ID in(select ID From T_EXAMPLE_B where D_DATE>=TO_DATE(20150120,’yyyy-mm-dd’))
另一种关于oracle日期格式的错误是:ORA-01840:输入值对于日期格式不够长
示比例如以下:select to_date(2015-01-01,‘yyyy-mm-dd‘) from dual
为了解决问题,我们也能够用改变传入的日期參数的格式,来解决,例如以下:
selectto_date(20150101,‘yyyy-mm-dd‘) from dual
5. 其它导致缺失右括号的原因
5.1 书写错误,确实缺少了一个括号
5.2 字段名缺少双引號
假设在创建表时,表字段名所有是大写,则不存在此问题
原文:http://www.cnblogs.com/zhchoutai/p/7399632.html
内容总结
以上是互联网集市为您收集整理的ORA-00907: 缺失右括号问题整理解决全部内容,希望文章能够帮你解决ORA-00907: 缺失右括号问题整理解决所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。