postgresql SQL語句變數使用

2021-08-15 10:20:46 字數 1733 閱讀 8707

一般變數使用我們都是放在函式裡面,這裡開發需求,要在sql直接使用變數,方便查詢一些問題,比如時間變數,要根據時間進行篩選

這裡有三種方法可以實現

1.psql命令使用變數

表資料如下:

hank=> select * from tb2;

c1 | c2 | c3

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

1 | hank | 2018-02-06 10:08:00.787503

2 | dazui | 2018-02-06 10:08:08.542481

3 | wahah | 2018-02-06 10:08:15.468527

4 | aaaaa | 2018-02-06 10:18:39.289523

sql文字如下

cat hank.sql

select * from tb2 where c2=:name and c3>=:time;

通過psql檢視

psql -v name="'hank'" -v time="'2018-02-06 10:08:00'" -f hank.sql

c1 | c2 | c3

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

1 | hank | 2018-02-06 10:08:00.787503

或者 psql -v name="'hank'" -v time="'2018-02-06 10:08:00'" -c '\i hank.sql'

c1 | c2 | c3

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

1 | hank | 2018-02-06 10:08:00.787503

效果一樣

2.\set使用變數

hank=> \set name hank

hank=> \set time '2018-02-06 10:09:00'

hank=> select * from tb2 where c2=:'name' and c3>=:'time';

c1 | c2 | c3

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

1 | hank | 2018-02-06 10:08:00.787503

3.通過定義引數實現

設定乙個session級別的引數,通過current_setting取值

hank=>  set session "asasd.time" to "2018-02-06 10:09:00"; 

sethank=>  select * from tb2 where c3 >= current_setting('asasd.time')::timestamp;

c1 |  c2   |             c3             

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

4 | aaaaa | 2018-02-06 10:18:39.289523

(1 row)

語句 switch語句

switch語句的特點如下 1 switch x 被選擇的內容 即x 只能是byte,short,int,char這四種型別 2 備選答案並沒有指定的順序,但是執行肯定是從第乙個case開始的,如果其中有匹配的case,執行完,通過該case的break就結束了switch。如果沒有匹配的case,...

Python while語句,for語句

usr bin python coding utf 8 filename whiletest.py num 23running true while running i int raw input input a number if i num print right running false e...

迴圈for語句 if語句

if語句 if 表示式 else if 表示式 for迴圈 for var i 0 i 10 i if語句 if 表示式 else if 表示式 for迴圈 for var i 0 i 10 i while迴圈 while 表示式 使用場景 for 次數確定的時候使用 while 直到滿足摸個條件的...