溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

postgresql——條件判斷函數(shù),系統(tǒng)函數(shù)等

發(fā)布時間:2020-07-05 13:19:08 來源:網(wǎng)絡(luò) 閱讀:4086 作者:一個笨小孩 欄目:數(shù)據(jù)庫

一、條件判斷函數(shù):

條件判斷函數(shù)稱為控制流程函數(shù),postgresql中,進行條件判斷的函數(shù)為:case。


1、CASE  expr  WHEN  v1  THEN  r1  [WHEN v2 THEN r2] [ELSE rn] END

該函數(shù)表示,如果expr值等于某個vn,就返回對應(yīng)位置THEN后面的結(jié)果,如果與所有值都不相等,就返回ELSE后面的rn。


例子:使用case value when語句執(zhí)行分支操作,如下:

testdb=# select case 2 when 1 then 'one' when 2 then 'two' else 'more' end;

 case 

------

 two

(1 row)


2、CASE WHEN v1 THEN r1  [WHEN v2 THEN r2] ELSE rn END

該函數(shù)表示,某個vn值為TRUE時,返回對應(yīng)位置THEN后面的結(jié)果,如果所有值都不為TRUE,就返回ELSE后的rn.


例子:使用case when語句執(zhí)行分支操作,如:

testdb=# select case when 1<0 then 'true' else 'false' end;

 case  

-------

 false

(1 row)



二、系統(tǒng)信息函數(shù):

postgresql中的系統(tǒng)信息有數(shù)據(jù)庫的版本號、當(dāng)前用戶名和連接數(shù),系統(tǒng)字符集、最后一個自動生成的ID值等。


1、獲取postgresql的版本號:version()

testdb=# select version();

                                                 version                                                  

----------------------------------------------------------------------------------------------------------

 PostgreSQL 9.6.9 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.4.7 20120313 (Red Hat 4.4.7-16), 64-bit

(1 row)


2、獲取用戶名的函數(shù):user和current_user


testdb=# select user,current_user;

 current_user | current_user 

--------------+--------------

 pguser       | pguser

(1 row)



三、加密和解密函數(shù)


1、加密函數(shù):MD5(str)

MD5(str)為字符串算出了一個MD5 128比特檢查和。該值以32為十六進制的二進制字符串的形式返回,若參數(shù)為null則會返回null。


例子:使用MD5函數(shù)加密字符串,如:

testdb=# select MD5 ('zhang');

               md5                

----------------------------------

 d0cd2693b3506677e4c55e91d6365bff

(1 row)


2、加密函數(shù):encode(str,pswd_str)

encode(str,pswd_str)使用pswd_str作為加密編碼,加密str。常見的加密編碼包括:base64,hex和escape。


例子:使用encode的加密字符串,如:

testdb=# select encode('secret','hex'),length(encode('secret','hex'));

    encode    | length 

--------------+--------

 736563726574 |     12

(1 row)



3、解密函數(shù):decode(crypt_str,pswd_str)

decode(crypt_str,pswd_str)使用pswd_str作為密碼,解密加密字符串crypt_str。crypt_str是由encode()返回的字符串。


例子:使用decode函數(shù)解密被encode加密字符串,如:

testdb=# select decode(encode('secret','hex'),'hex');

     decode     

----------------

 \x736563726574

(1 row)


-------------------------------------------------

改變數(shù)據(jù)類型的函數(shù):


cast(s ,AS type)將一個類型的值轉(zhuǎn)換為另一個類型的值。


例子:使用cast函數(shù)進行數(shù)據(jù)類型的轉(zhuǎn)換,如下:

testdb=# select cast(100 as char(2));

 bpchar 

--------

 10

(1 row)


向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI