我必须编写一个对和Oracle有效的SELECT语句。我必须使用旧的客户数据库,所以我不能改变数据库设计中的任何东西.
问题是该表有一个可空列“project”,它是一个varchar,在某些情况下是由空字符串填充的-- oracle将该字符串转换为NULL。那么,如何选择所有具有非空“项目”的列?
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
谢谢你,马科
发布于 2013-11-18 00:42:24
由于条件'' = ''
只在Server中为真(相当于'' IS NOT NULL
),而条件'' IS NULL
仅在Oracle中为真,因此可以使用以下方法:
WHERE ( project > '' AND '' = '') -- for SQL-Server
OR ( project IS NOT NULL AND '' IS NULL) -- for Oracle
请注意,如果您的值仅为空格,则Server和Oracle将对它们进行不同的处理。测试1 (Oracle)和2(Server)。
发布于 2013-11-18 00:46:22
您可以使用NULLIF()
,它在SQL Server和甲骨文中都可用(它是ANSI标准的一部分)。
select *
from table
where nullif(project, '') is not null
这是因为Oracle将空字符串计算为空字符串为NULL。值得注意的是,如果第一个表达式为NULL,Oracle不会计算NULLIF()
,但它确实是这样工作的。
发布于 2013-11-18 00:39:16
事实:
因此,如果您有一个具有相同内容的Oracle和Server数据库,则结果是相同的,这是您真正想要的
where (project is not null OR project <> '')
https://stackoverflow.com/questions/20043247
复制