首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORA-00936:缺失表达式错误代码

ORA-00936:缺失表达式错误代码
EN

Stack Overflow用户
提问于 2015-04-13 13:18:06
回答 1查看 12.8K关注 0票数 0

我是新来的,我想知道是否有人能用我的ORA-00936查询来解释这个ORA-00936错误。

代码语言:javascript
复制
select Count(Auftragsnr) as Open_Orders
from wa_kopf
where convert(varchar(4), Aender_Datum, 104) = convert(varchar(4), getdate(), 104)
and zustand < (60);

获取以下错误:

14:47:37选择-0行,0.000秒ORA-00936:缺失表达式

任何帮助都将不胜感激。

问候

JRidge

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-13 14:21:20

您使用的是Server语法,它不能使用Oracle数据库。您似乎在尝试将日期格式化为dd.mm.yyyy (但在某种程度上是以4个字符的字符串)。Oracle中也没有getdate函数,但它确实有sysdate

因此,我认为您想要做的与Oracle等价的是:

代码语言:javascript
复制
where to_char(Aender_Datum, 'dd.mm.yyyy') = to_char(sysdate, 'dd.mm.yyyy')

但这仅仅意味着您将日期作为字符串进行比较,这通常不是一个好主意。如果您从今天开始寻找任何值,您可以使用函数,默认情况下,它从日期中剥离时间部分;如果您的列只代表日期,而且时间总是午夜,那么您可以这样做:

代码语言:javascript
复制
where Aender_Datum = trunc(sysdate)

如果您的列有不同的时间,那么您也可以截断它:

代码语言:javascript
复制
where trunc(Aender_Datum) = trunc(sysdate)

..。但是,如果对列进行索引,则会对性能产生影响,另一种方法是使用范围比较:

代码语言:javascript
复制
where Aender_Datum >= trunc(sysdate)
and Aender_Datum  < trunc(sysdate) + 1
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29606305

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档