zoukankan      html  css  js  c++  java
  • Postgresql与Oralce常用用法区别总结

    日期操作 

    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;
    

    上面的函数我们就不多作解释了,很容易理解,我们来说一下mysqlif()函数,如果第一个参数为

    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

  • 相关阅读:
    Why does my Authorize Attribute not work?
    百度网页搜索部来自Console的招聘信息
    Javascript 日期时间超强正则表达式
    解决SQL Server [Suspect]
    我回来了
    不忘初心
    WEB系统技术开发方向
    使用postman模拟登录请求
    什么是蓝绿部署?
    element-ui Cascader 级联选择器示例
  • 原文地址:https://www.cnblogs.com/space-place/p/8543811.html
Copyright © 2011-2022 走看看