標籤:字串操作 sql post foo express day timestamp 替換 格式
日期操作 1. 操作當前日期和時間
oracle Select SYSDATE FROM dual;PostgreSQL Select CURRENT_DATE;
Select NOW();返回日期時間還包括時區
2. 操作時間的擷取子域
oracle : Select TO_CHAR(SYSDATE,‘Day‘) FROM dual;PostgreSQL : Select DATE_PART(‘dow‘,date ‘now‘); //dow = day of week Select DATE_PART(‘hour‘, timestamp ‘now‘)
oracle中的TO_CHAR可以從日
期中拿到所需要的子域,日期,小時,分鐘等。
3. 時間間隔,在一些應用中需要知道兩個時間間隔多遠
oracle :Select TO_DATE(‘25-Nov-2000‘,‘dd-mon-yyyy‘) - TO_DATE(‘25-Aug-1969‘,‘dd-mon-yyyy‘) FROM dual;PostgreSQL : Select AGE(CURRENT_DATE, ‘25-Aug-1969‘);
測量不同時間的間隔,不同的資料庫之間函數文法有很大的不同。
4. 日期時間格式化
oracle Select TO_CHAR(SYSDATE,‘dd-Mon-yyyy hh:mi:ss PM‘) FROM dual;PostgreSQL Select TO_CHAR (timestamp(CURRENT_DATE),‘dd-Mon-yyyy hh:mi:ss PM‘);
字串操作1. 字串中包含字元
oracle Select INSTR(‘Great‘,‘eat‘) FROM dual;PostgreSQL Select POSITION(‘eat‘ IN ‘great‘);
通過上面的這些函數可以確定字串在另一個字串中的位置(及另一個字串包含這個字串的位置)。
2. 字串去掉空格
oracle Select LTRIM(‘ sql_in_a_nutshell‘), Select RTRIM(‘sql_in_a_nutshell ‘), TRIM(‘ sql_in_a_nutshell ‘) FROM dual;PostgreSQL Select TRIM(LEADING FROM ‘ sql_in_a_nutshell‘), TRIM(TRAILING FROM ‘sql_in_a_nutshell ‘), TRIM(BOTH FROM ‘ sql_in_a_nutshell ‘);
3. 上面清除空格相反的操作,添加空格
oracle Select LPAD((‘sql_in_a_nutshell‘, 20, ‘ ‘), RPAD((‘sql_in_a_nutshell‘, 20, ‘ ‘) FROM dual;PostgreSQL Select LPAD(‘sql_in_a_nutshell‘, 20, ‘ ‘), RPAD(‘sql_in_a_nutshell‘, 20, ‘ ‘);
上面支援該操作的資料庫的函數都相同,並且都包括從左和右添加空格的方法。
4. 字串替換
oracle [returns ‘wabbit_hunting_season‘] Select REPLACE(‘wabbit_season‘,‘it_‘,‘it_hunting_‘) FROM dual;PostgreSQL Select TRANSLATE(‘wabbit_season‘,‘it_‘,‘it_hunting_‘); Select replace(‘wabbit_season‘,‘it_‘,‘it_hunting_‘);
5. 字串截取
oracle Select SUBSTR(‘wabbit_duck_season‘, 7, 11) FROM dual;PostgreSQL Select SUBSTR(‘wabbit_duck_season‘, 7, 11);
條件判斷1. 條件判斷
oracle Select DECODE (payments_info,‘CR‘,‘Credit‘,‘DB‘,‘Debit‘, null) FROM dual;PostgreSQL Select CASE WHEN foo = ‘hi‘ THEN ‘there‘ WHEN foo = ‘good‘ THEN ‘bye‘ ELSE ‘default‘ END FROM t2;
上面的函數我們就不多作解釋了,很容易理解,我們來說一下mysql的if()函數,如果第一個參數為
true那麼返回地二個參數,否則返回第三個參數。
2. 判斷空函數
oracle Select NVL(foo,‘Value is Null‘) FROM dual;PostgreSQL Select coalesce(foo,‘Value is Null‘)
3. 下面與上面的函數不同
oracle Select DECODE(foo,‘Wabbits!‘,NULL) FROM dual;PostgreSQL Select NULLIF(foo, ‘Wabbits!‘);
函數文法:NULLIF(expression1, expression2)
如果 expression1 等於 expression2則返回 NULL,如果expression1的值為null,也返回NULL
Postgresql與Oralce常用用法區別總結