Postgresql與Oralce常用用法區別總結


日期操作 

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;

上面的函數我們就不多作解釋了,很容易理解,我們來說一下mysqlif()函數,如果第一個參數為

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM