瀚高DB兼容MySQL if函数
目錄
環(huán)境
癥狀
問題原因
解決方案
環(huán)境
系統(tǒng)平臺:Linux x86-64 Red Hat Enterprise Linux 7
版本:4.5
癥狀
MySQL if函數(shù)在瀚高DB當(dāng)中沒有,源應(yīng)用在用到if函數(shù)時,就會報if函數(shù)不存在的錯誤信息。為此,我們需要根據(jù)業(yè)務(wù)需求自定義if函數(shù)。
問題原因
瀚高中沒有if函數(shù)此函數(shù)。
解決方案
If函數(shù)說明
在mysql中if()函數(shù)的用法類似于java中的三目表達(dá)式,其用處也比較多,具體語法如下:
IF(expr1,expr2,expr3),如果expr1的值為true,則返回expr2的值,如果expr1的值為false,則返回expr3的值。
MySQL中,if函數(shù)使用非常廣泛,支持的類型也很多。我們可以自定義if函數(shù)并實現(xiàn)其功能,但并不是能夠百分百富縣MySQL的if函數(shù)功能。所以只能根據(jù)應(yīng)用所用場景或者功能定制寫if函數(shù)。下面寫幾個例子。
自定義IF函數(shù)例子
第二、三個參數(shù)是一樣的數(shù)據(jù)類型。
第二、三個參數(shù)都是varchar類型:
create or replace function if(bln boolean,inValue1 VARCHAR,inValue2 VARCHAR) returns varchar as $$ begin if bln=true thenreturn inValue1; elsereturn inValue2; end if; end; $$ language plpgsql;第二、三個參數(shù)都是numeric類型:
create or replace function if(bln boolean,inValue1 numeric,inValue2 numeric) returns numeric as $$ begin if bln=true thenreturn inValue1; elsereturn inValue2; end if; end; $$ language plpgsql;如果有其他情況,按照使用場景的數(shù)據(jù)類型進(jìn)行更換便是,需要注意的是返回值的數(shù)據(jù)類型要保持一致。
總結(jié)
以上是生活随笔為你收集整理的瀚高DB兼容MySQL if函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [地质学笔记]粒度概率累积曲线
- 下一篇: mysql显示中文乱码问题解决办法(部分