拼接符“II”在Oracle和HGDB中使用的差异

文章目录

环境

系统平台:Microsoft Windows (64-bit) 10

版本:5.6.4

症状

如下情况所示:在Oracle中和HGDB中使用拼接符"||"结果不一致。

Oracle:

sql 复制代码
SQL> select null||'123' from dual ;

NUL
--------------------------------
123

HGDB:

sql 复制代码
highgo=# select null||'123' from dual;
 ?column?
--------------------------------

(1 行记录)

问题原因

在Oracle中和HGDB中使用拼接符"||"拼接NULL时,结果不一致。

解决方案

解决方案一:

使用concat()函数进行拼接,取代"||",如下所示:

sql 复制代码
highgo=# select concat(null,'123');
 concat
--------
 123
(1 行记录)

解决方案二:

使用coalesce()函数将null转换为'',如下所示:

sql 复制代码
highgo=# select coalesce(null,'')||'123';
 ?column?
----------
 123
(1 行记录)
相关推荐
心态还需努力呀3 小时前
当时序数据不再“只是时间”:金仓数据库如何在复杂场景中拉开与 InfluxDB 的差距
数据库
宇灬宇3 小时前
oracle误drop表,通过回收站恢复
数据库·oracle
Albert Tan3 小时前
Oracle EBS 12.2/12.1 开放本地或远程访问Weblogic
数据库·oracle
一个处女座的程序猿O(∩_∩)O3 小时前
从InfluxDB到金仓:时序数据库性能拐点已至?
数据库·时序数据库
数据和云3 小时前
Oracle没有退路
数据库·oracle·vr
Gauss松鼠会3 小时前
【openGauss】让gsql和sqlplus输出包含有SQL及数据的完全一致的文本文件
数据库·sql·database·opengauss
盛世宏博北京3 小时前
分布式库房集中管!云端 “八防” 监控平台,多站点统一可视化运维
大数据·网络·数据库·档案温湿度
言之。3 小时前
向量数据库
数据库
Debroon3 小时前
Graphiti:Cypher与SQL的“同声传译“,一个让图数据库和关系数据库握手言和的验证器
数据库·sql