意外发现openGauss兼容Oracle的几个条件表达式

意外发现openGauss兼容Oracle的几个条件表达式

最近工作中发现openGauss在兼容oracle模式下,可以兼容常用的两个表达式,因此就随手测试了一下。

查看数据库版本

复制代码
[omm@openGauss ~]$ gsql -r
gsql ((openGauss 6.0.0-RC1 build ed7f8e37) compiled at 2024-03-31 11:59:31 commit 0 last mr  )
Non-SSL connection (SSL connection is recommended when requiring high-security)
Type "help" for help.

openGauss=# select version();
                                                                          version                                                                          
-----------------------------------------------------------------------------------------------------------------------------------------------------------
 (openGauss 6.0.0-RC1 build ed7f8e37) compiled at 2024-03-31 11:59:31 commit 0 last mr   on x86_64-unknown-linux-gnu, compiled by g++ (GCC) 10.3.0, 64-bit
(1 row)

查看openGauss数据库的兼容模式

复制代码
testdb=# select datname,datcompatibility from pg_database;
  datname  | datcompatibility 
-----------+------------------
 template1 | A
 template0 | A
 testdb    | A
 postgres  | A
(4 rows)

decode(expr1, expr2, result1 ,...)

将表达式base_expr与后面的每个compare(n) 进行比较,如果匹配返回相应的value(n)。如果没有发生匹配,则返回default。

复制代码
testdb=# select id,name,address,decode(address,'北京市','BJ','南京市','NJ','ZG') JC from t1;
 id | name | address | jc 
----+------+---------+----
  2 | zs2  | 北京市  | BJ
  4 | zs4  |         | ZG
  1 | zs1  | 南京市  | NJ
(3 rows)

nvl(expr1, expr2)

如果value1为NULL则返回value2,如果value1非NULL,则返回value1。

复制代码
testdb=# select * from t1;
 id | name | address 
----+------+---------
  2 | zs2  | 北京市
  4 | zs4  | 
(2 rows)
testdb=# select id,name,nvl(address,'上海') from t1;
 id | name |  nvl   
----+------+--------
  2 | zs2  | 北京市
  4 | zs4  | 上海
(2 rows)

decode和nvl的使用方法与在Oracle中的使用方式一致,并无差别,这里不做详细介绍。在查看文档过程,官网文档函数和操作符章节与whale插件支持的函数相关章节两个地方都描述了对nvl、decode的支持情况,但是也未发现两处的区别在哪儿?不清楚当使用插件和不使用的情况的功能区别在哪儿呢?另外也发现在oracle中开发经常使用的nvl2条件表达式也支持,但是使用需要使用whale插件后才可以使用;后来想安装whale插件测试,但是也没有对应版本插件下载的地方,只能下载源码自行编译,对于这块感觉还是有点不方便。由于时间的问题也没有进一步编译插件源码进行测试。

相关推荐
phltxy19 小时前
Seata 2.2.0:下载、部署与 Nacos + MySQL 集成教程
数据库·mysql·spring cloud·微服务
努力努力再努力wz19 小时前
【Qt 入门系列】从应用场景到开发环境:建立对 Qt 的第一层认知
c语言·开发语言·数据库·c++·b树·qt·缓存
毋语天19 小时前
Milvus 向量数据库基础
数据库·milvus
m0_7406532220 小时前
告别重复编码-Symfony自动化开发指南
jvm·数据库·python
iAm_Ike20 小时前
placeholder属性在IE9下有效吗_低版本表单提示替代方法【技巧】
jvm·数据库·python
牧瀬クリスだ20 小时前
MYSQL的索引与事务
数据库·mysql
李木子qaq20 小时前
什么是数据库代理
数据库·proxy模式
LNN202220 小时前
半导体设备上位机 Qt 实现计划
开发语言·数据库·qt
牧瀬クリスだ20 小时前
MYSQL的视图
数据库·mysql
m0_7414817820 小时前
SQL删除包含敏感信息的数据_使用数据脱敏后执行删除
jvm·数据库·python