日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

瀚高DB兼容MySQL if函数

發布時間:2023/12/20 数据库 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 瀚高DB兼容MySQL if函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄
環境
癥狀
問題原因
解決方案

環境
系統平臺:Linux x86-64 Red Hat Enterprise Linux 7
版本:4.5
癥狀
MySQL if函數在瀚高DB當中沒有,源應用在用到if函數時,就會報if函數不存在的錯誤信息。為此,我們需要根據業務需求自定義if函數。

問題原因
瀚高中沒有if函數此函數。

解決方案
If函數說明
在mysql中if()函數的用法類似于java中的三目表達式,其用處也比較多,具體語法如下:

IF(expr1,expr2,expr3),如果expr1的值為true,則返回expr2的值,如果expr1的值為false,則返回expr3的值。

MySQL中,if函數使用非常廣泛,支持的類型也很多。我們可以自定義if函數并實現其功能,但并不是能夠百分百富縣MySQL的if函數功能。所以只能根據應用所用場景或者功能定制寫if函數。下面寫幾個例子。

自定義IF函數例子
第二、三個參數是一樣的數據類型。

create or replace function if(bln boolean,inValue1 anyelement,inValue2 anyelement)returns anyelement as$$beginif bln=true thenreturn inValue1;elsereturn inValue2;end if;end;$$language plpgsql;

第二、三個參數都是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;

第二、三個參數都是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;

如果有其他情況,按照使用場景的數據類型進行更換便是,需要注意的是返回值的數據類型要保持一致。

總結

以上是生活随笔為你收集整理的瀚高DB兼容MySQL if函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。