<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

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

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

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

    我要在select語(yǔ)句中來(lái)判斷某個(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');

    通過(guò)上面的這些函數(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ù)我們就不多作解釋了,很容易理解,我們來(lái)說(shuō)一下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 閱讀(788) 評(píng)論(2)  編輯  收藏 所屬分類: 數(shù)據(jù)庫(kù)

    評(píng)論

    # re: 常用數(shù)據(jù)庫(kù)函數(shù)對(duì)比(1)[未登錄](méi)  回復(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
    主站蜘蛛池模板: 亚洲成人免费网站| 日韩少妇内射免费播放| 性色av无码免费一区二区三区| 亚洲av成人一区二区三区在线播放| 亚洲国产精品丝袜在线观看| 午夜精品免费在线观看| 亚洲精品无码高潮喷水A片软| 国产亚洲老熟女视频| aⅴ在线免费观看| 国产亚洲高清在线精品不卡| 久久青草亚洲AV无码麻豆| 高清国语自产拍免费视频国产 | www.亚洲精品.com| 小日子的在线观看免费| 色噜噜噜噜亚洲第一| 久久国产精品亚洲一区二区| 曰皮全部过程视频免费国产30分钟| 国产免费牲交视频免费播放| 中国亚洲呦女专区| 亚洲va久久久噜噜噜久久男同| 国产一级淫片a免费播放口之| 久久大香伊焦在人线免费| 国产成人久久精品亚洲小说| 久久亚洲精品成人无码网站| 亚洲日韩国产精品乱| 18禁无遮挡无码网站免费| 久久精品中文字幕免费| 日韩成人毛片高清视频免费看| 国产免费av片在线播放| 一级毛片不卡片免费观看| 亚洲人成网站在线观看青青| 亚洲欧美国产国产综合一区 | 国产在线ts人妖免费视频| 好吊妞998视频免费观看在线| 成人免费视频网址| 天天摸天天碰成人免费视频| 永久免费毛片手机版在线看| 日韩一级视频免费观看| 人人狠狠综合久久亚洲高清| 亚洲日韩国产一区二区三区| 亚洲一区二区三区乱码A|