首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Oracle空字符串/空

Oracle空字符串/空
EN

Stack Overflow用户
提问于 2013-11-18 08:33:48
回答 3查看 1.6K关注 0票数 5

我必须编写一个对和Oracle有效的SELECT语句。我必须使用旧的客户数据库,所以我不能改变数据库设计中的任何东西.

问题是该表有一个可空列“project”,它是一个varchar,在某些情况下是由空字符串填充的-- oracle将该字符串转换为NULL。那么,如何选择所有具有非空“项目”的列?

代码语言:javascript
运行
复制
WHERE project IS NOT NULL                   works for oracle
WHERE project <> ''                         works for MS
WHERE project IS NOT NULL AND project <> '' works for MS, but not for Oracle

谢谢你,马科

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-11-18 08:42:24

由于条件'' = ''只在Server中为真(相当于'' IS NOT NULL),而条件'' IS NULL仅在Oracle中为真,因此可以使用以下方法:

代码语言:javascript
运行
复制
WHERE ( project > '' AND '' = '')              -- for SQL-Server
   OR ( project IS NOT NULL AND '' IS NULL)    -- for Oracle

请注意,如果您的值仅为空格,则Server和Oracle将对它们进行不同的处理。测试1 (Oracle)2(Server)

票数 7
EN

Stack Overflow用户

发布于 2013-11-18 08:46:22

您可以使用NULLIF(),它在SQL Server甲骨文中都可用(它是ANSI标准的一部分)。

代码语言:javascript
运行
复制
select *
  from table
 where nullif(project, '') is not null

这是因为Oracle将空字符串计算为空字符串为NULL。值得注意的是,如果第一个表达式为NULL,Oracle不会计算NULLIF(),但它确实是这样工作的。

票数 2
EN

Stack Overflow用户

发布于 2013-11-18 08:39:16

事实:

  • Oracle将空转换为空
  • Server不进行翻译。

因此,如果您有一个具有相同内容的Oracle和Server数据库,则结果是相同的,这是您真正想要的

代码语言:javascript
运行
复制
where (project is not null OR project <> '')
票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20043247

复制
相关文章

相似问题

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