常用數(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ù)