oracle Select SYSDATE FROM dual; PostgreSQL Select CURRENT_DATE;
Select NOW();返回日期时间还包括时区mysql
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能够从日sql
期中拿到所须要的子域,日期,小时,分钟等。shell
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');
测量不一样时间的间隔,不一样的数据库之间函数语法有很大的不一样。数据库
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');
oracle Select INSTR('Great','eat') FROM dual; PostgreSQL Select POSITION('eat' IN 'great');
经过上面的这些函数能够肯定字符串在另外一个字符串中的位置(及另外一个字符串包含这个字符串的位置)。express
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 ');
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, ' ');
上面支持该操做的数据库的函数都相同,而且都包括从左和右添加空格的方法。oracle
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_');
oracle Select SUBSTR('wabbit_duck_season', 7, 11) FROM dual; PostgreSQL Select SUBSTR('wabbit_duck_season', 7, 11);
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那么返回地二个参数,不然返回第三个参数。spa
oracle Select NVL(foo,'Value is Null') FROM dual; PostgreSQL Select coalesce(foo,'Value is Null')
oracle Select DECODE(foo,'Wabbits!',NULL) FROM dual; PostgreSQL Select NULLIF(foo, 'Wabbits!');
函数语法:NULLIF(expression1, expression2)
若是 expression1 等于 expression2则返回 NULL,若是expression1的值为null,也返回NULLblog