Postgresql與Oralce常用用法區別總結

來源:互聯網
上載者:User

標籤:字串操作   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常用用法區別總結

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.