内容简介:翻译自:https://stackoverflow.com/questions/37330260/sql-using-if-not-null-on-a-concatenation
如果我有桌子
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
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 解决golang使用elastic连接elasticsearch时自动转换连接地址
- 使用 WebSocket 连接 RabbitMQ
- 使用poll机制处理多连接
- 使用select机制处理多连接
- Laravel 使用多个数据库连接
- 使用 ssh 连接 VirtualBox 虚拟机
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
机器学习实践指南
麦好 / 机械工业出版社 / 2014-4-1 / 69.00
《机器学习实践指南:案例应用解析》是机器学习及数据分析领域不可多得的一本著作,也是为数不多的既有大量实践应用案例又包含算法理论剖析的著作,作者针对机器学习算法既抽象复杂又涉及多门数学学科的特点,力求理论联系实际,始终以算法应用为主线,由浅入深以全新的角度诠释机器学习。 全书分为准备篇、基础篇、统计分析实战篇和机器学习实战篇。准备篇介绍了机器学习的发展及应用前景以及常用科学计算平台,主要包括统......一起来看看 《机器学习实践指南》 这本书的介绍吧!