Jason ---分享,共同進(jìn)步

          激情成就夢(mèng)想,努力創(chuàng)造未來
          隨筆 - 53, 文章 - 1, 評(píng)論 - 45, 引用 - 0
          數(shù)據(jù)加載中……

          常用數(shù)據(jù)庫(kù)函數(shù)對(duì)比(1)

          今天在處理postgreSQL數(shù)據(jù)庫(kù)的函數(shù)的時(shí)候。遇到了一個(gè)問題

          我要在select語(yǔ)句中來判斷某個(gè)字段的屬性是否為空,或者是否為一個(gè)特定的值,我需要作判斷,在
          oracle中我們會(huì)用nvl decode 等函數(shù)。同樣 mysql 中會(huì)有ifnull,if 函數(shù)。有時(shí)候會(huì)搞混,忘記了那

          個(gè)哪個(gè)數(shù)據(jù)庫(kù)支持這個(gè)函數(shù)了。

          于是就總結(jié)一下,不同數(shù)據(jù)庫(kù)中的一些常用函數(shù),這樣方便以后使用。

          一,日期操作 

          1,操作當(dāng)前日期和時(shí)間

          Microsoft SQL Server
            Select GETDATE()
            GO
          MySQL 返回日期不包括時(shí)間
            Select CURDATE();
          MySQL 返回日期和時(shí)間
            Select NOW();
          oracle
            Select SYSDATE  FROM dual;
          PostgreSQL
            Select CURRENT_DATE;
            Select NOW();返回日期時(shí)間還包括時(shí)區(qū)

          2,操作時(shí)間的獲取子域

          Microsoft SQL Server
            Select DATEPART(dw, GETDATE())
            GO

          MySQL
            Select DAYNAME(CURDATE());

          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')


          Microsoft SQL 中調(diào)用函數(shù)DATEPART語(yǔ)法為: DATEPART(datetype, date_expression).函數(shù)參數(shù)

          datetype 為month, day, week, day of week 等,而第二個(gè)參數(shù)為包含日期類型的字段或者一個(gè)真實(shí)

          的日期值,而mysql中的DAYNAME函數(shù)就是直接指定了當(dāng)前日期為星期幾,oracle中的TO_CHAR可以從日

          期中拿到所需要的子域,日期,小時(shí),分鐘等。

          3,時(shí)間間隔,在一些應(yīng)用中需要知道兩個(gè)時(shí)間間隔多遠(yuǎn)

          Microsoft SQL Server
            Select DATEDIFF(dd, '1/1/01', GETDATE())
            GO

          MySQL
            Select FROM_DAYS(TO_DAYS(CURDATE()) -
            TO_DAYS('2001-11-25'));

          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');

          測(cè)量不同時(shí)間的間隔,不同的數(shù)據(jù)庫(kù)之間函數(shù)語(yǔ)法有很大的不同。

          4,日期時(shí)間格式化

          Microsoft SQL Server
            Select CONVERT(VARCHAR(11), GETDATE(), 102)
            GO
          MySQL
            Select DATE_FORMAT( \"2001-11-25\", \"%M %e, %Y\");
          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,字符串中包含字符

          Microsoft SQL Server
            Select CHARINDEX('eat', 'great')
            GO
          MySQL
            Select POSITION('eat' IN 'great');
          oracle
            Select INSTR('Great','eat') FROM dual;
          PostgreSQL
            Select POSITION('eat' IN 'great');

          通過上面的這些函數(shù)可以確定字符串在另一個(gè)字符串中的位置(及另一個(gè)字符串包含這個(gè)字符串的位置)。

          2,字符串去掉空格

          Microsoft SQL Server
            Select LTRIM('  sql_in_a_nutshell'),
               Select RTRIM('sql_in_a_nutshell      '),
               Select LTRIM(RTRIM('     sql_in_a_nutshell     ')
            GO
          MySQL
            Select LTRIM('  sql_in_a_nutshell'),
               Select RTRIM('sql_in_a_nutshell      '),
               Select TRIM('     sql_in_a_nutshell      '),
               Select TRIM(BOTH FROM '     sql_in_a_nutshell     ');
          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,上面清除空格相反的操作,添加空格

          Microsoft SQL Server
            Not supported
          MySQL
            Select LPAD('sql_in_a_nutshell', 20, ' '), 
              RPAD('sql_in_a_nutshell', 20, ' ');
          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, ' ');
          上面支持該操作的數(shù)據(jù)庫(kù)的函數(shù)都相同,并且都包括從左和右添加空格的方法。

          4,字符串替換

          Microsoft SQL Server [returns 'wabbit_hunting_season']
            Select STUFF('wabbit_season', 7, 1, '_hunting_')
            GO
          MySQL [returns 'wabbit_hunting_season']
            Select
               REPLACE('wabbit_season','it_','it_hunting_');
          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,字符串截取

          Microsoft SQL Server
            Select SUBSTRING('wabbit_duck_season', 7, 11)
            GO
          MySQL
            Select
               SUBSTRING('wabbit_duck_season', 7, 11);
          oracle
            Select SUBSTR('wabbit_duck_season', 7, 11)
            FROM dual;
          PostgreSQL
            Select SUBSTR('wabbit_duck_season', 7, 11);

          三,條件判斷

          1,條件判斷
          Microsoft SQL Server
            Select  CASE
                WHEN foo = 'hi'   THEN 'there'
                WHEN foo = 'good' THEN 'bye'
                ELSE 'default'
            END
            FROM t2
            GO

          MySQL
             select if(('11'='11'),'1','2')
             select if(2>1,'1','2')


          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;

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

          true那么返回地二個(gè)參數(shù),否則返回第三個(gè)參數(shù)。

          2,判斷空函數(shù)


          Microsoft SQL Server
            Select ISNULL(foo, 'Value is Null')
            GO

          MySQL
             select ifnull(122,'aaa')

          oracle
            Select NVL(foo,'Value is Null')
            FROM dual;
          PostgreSQL 
            Select coalesce(foo,'Value is Null')


          3,下面與上面的函數(shù)不同

          Microsoft SQL Server [returns NULL when foo equates to 'Wabbits!']
            Select NULLIF(foo, 'Wabbits!')
            GO
          MySQL
            N/A
          oracle
            Select DECODE(foo,'Wabbits!',NULL)
            FROM dual;
          PostgreSQL
            Select NULLIF(foo, 'Wabbits!');
          函數(shù)語(yǔ)法:NULLIF(expression1, expression2)
          如果 expression1 等于 expression2則返回 NULL,如果expression1的值為null,也返回NULL

          posted on 2008-07-30 17:20 agun 閱讀(795) 評(píng)論(2)  編輯  收藏 所屬分類: 數(shù)據(jù)庫(kù)

          評(píng)論

          # re: 常用數(shù)據(jù)庫(kù)函數(shù)對(duì)比(1)[未登錄]  回復(fù)  更多評(píng)論   

          很好,收藏了
          2008-08-01 11:47 | hehe

          # re: 常用數(shù)據(jù)庫(kù)函數(shù)對(duì)比(1)  回復(fù)  更多評(píng)論   

          我也收藏了,不錯(cuò)
          2008-12-24 10:44 | A8
          主站蜘蛛池模板: 库伦旗| 太和县| 恭城| 东乡县| 西充县| 和田县| 屏南县| 达日县| 杨浦区| 万宁市| 寻乌县| 古蔺县| 望谟县| 汪清县| 靖安县| 东至县| 尚志市| 喀喇沁旗| 上饶市| 宝应县| 金湖县| 伊宁县| 灵山县| 鲁山县| 凤城市| 威宁| 志丹县| 汨罗市| 女性| 宣汉县| 广水市| 湾仔区| 岐山县| 慈利县| 澎湖县| 天门市| 蓬安县| 泽库县| 黔西| 清徐县| 侯马市|