SQL在连接中使用If Not Null

栏目: 数据库 · 发布时间: 7年前

内容简介:翻译自:https://stackoverflow.com/questions/37330260/sql-using-if-not-null-on-a-concatenation

如果我有桌子

SQL在连接中使用If Not Null

SELECT (Firstname || '-' || Middlename || '-' || Surname)  AS example_column
FROM example_table

这将显示Firstname-Middlename-Surname,例如

John--Smith
Jane-Anne-Smith

第二个(Jane的)显示正确,但是由于John没有中间名,我希望它忽略第二个破折号.

我怎么能把一个IF Middlename = NULL语句放入其中才能显示John-Smith

这是我的建议:

PostgreSQL和其他 SQL 数据库中的’a’|| NULL为空:

select firstname || coalesce ('-' || middlename, '') || '-' || surname ...

Oracle和其他SQL数据库中的’a’|| NULL =’a’:

select first name || decode (middlename, NULL, '', '-' || middlename) || '-' || surname...

我喜欢简洁.对于任何维护 程序员 来说,中间名是否为空都不是很有趣. CASE开关非常好,但它们很笨重.我想尽可能避免重复相同的列名(“中间名”).

正如@Prdp所指出的那样,答案是特定于RDBMS的.具体的是服务器是否将零长度字符串视为等效于NULL,这确定连接NULL是否产生NULL.

通常,COALESCE对于PostgreSQL样式的空字符串处理最简洁,而DECODE(* VALUE *,NULL,”…用于Oracle样式的空字符串处理.

翻译自:https://stackoverflow.com/questions/37330260/sql-using-if-not-null-on-a-concatenation


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

正当法律程序简史

正当法律程序简史

(美)约翰·V.奥尔特 / 杨明成、陈霜玲 / 商务印书馆 / 2006-8 / 14.00元

本书的主题——正当法律程序,是英美法的核心概念,它使诸如法治、经济自由、个人自治以及免于政府专断行为的侵害等价值观念具体化,因而是法学领域一个永恒的主题,数百年以来一直是法学家、法官及律师关注的重点。本书以极为简洁、精确的语言总结了五百年法律发展的恢弘历史,为人们描述了正当法律程序观念发展演变的清晰轨迹。而沿着这条轨迹,人们可以准确地了解正当法律程序这一重要概念所包含的广泛的问题。 作为一本......一起来看看 《正当法律程序简史》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具