pg 对时间的处理还是很灵活的, + - * /  都有支持

期间有个extract 函数还是很有用的,我们先来看看几个例子:[code]

postgres=# select extract(epoch from '1970-01-01'::timestamp) ;          
date_part 
-----------
         0
(1 row)

postgres=# select extract(epoch from '1970-01-01 00:00:01'::timestamp) ; 
date_part 
-----------
         1
(1 row)

postgres=# select  extract(epoch from now()-'2013-07-01'::timestamp) ; 
   date_part    
----------------
1936767.072764
(1 row)

postgres=# 
[/code]上面的例子是求出从1970-01-01 00:00:00 开始的秒数

extract 函数的功能是从时间中抽出相应的字段

他的使用格式:
EXTRACT(field FROM source)

其中field 包含以下几个值:

century:  世纪 

postgres=# select extract(century from '2013-07-01'::date) ; 
date_part 
-----------
        21
(1 row)

day : 一个月里的第几天[code]

postgres=# select extract(day from '2013-07-23'::date) ;   
date_part 
-----------
        23
(1 row)

postgres=# select extract(day from '2013-07-23 09:15:23'::timestamp) ;     
date_part 
-----------
        23
(1 row)

postgres=# select extract(day from '2013-07-23 09:15:23'::date) ;          
date_part 
-----------
        23
(1 row)

postgres=# select  extract(day from interval '40 days 3 hours' ) ;
date_part 
-----------
        40
(1 row)

[/code]decade : 10年期  ,第几个10年 

postgres=# select extract(decade from '2013-07-23 09:15:23'::date) ;    
date_part 
-----------
       201
(1 row)

dow   一周里的第几天 (sunday =0  saturday=6) 

postgres=# select extract(dow from '2013-07-23 09:15:23'::date) ;       
date_part 
-----------
         2
(1 row)

postgres=# select extract(dow from '2013-07-21 09:15:23'::date) ;  
date_part 
-----------
         0
(1 row)

doy  :  一年里的第几天(1-365/366)

postgres=# select extract(doy from '2013-07-21 09:15:23'::date) ;  
date_part 
-----------
       202
(1 row)

hour:  一天里小时数(0-23) 

postgres=# SELECT EXTRACT(HOUR FROM TIMESTAMP '2013-07-21 09:15:23');  
date_part 
-----------
         9
(1 row)

postgres=# select extract(hour from '2013-07-21 09:15:23'::date) ;     
date_part 
-----------
         0
(1 row)

注意这里,因为我们把'2013-07-21 09:15:23'::date) 转为date 类型是没有小时的,所以返回0 ,上面的timestamp 是有小时的,正确返回

isodow :  ISO 标准一周的天数 sunday=7  monday=1 

postgres=# select extract(isodow from '2013-07-21 09:15:23'::date) ;     
date_part 
-----------
         7
(1 row)

postgres=# select extract(dow from '2013-07-21 09:15:23'::date) ;       
date_part 
-----------
         0
(1 row)

postgres=# select extract(isodow from '2013-07-21 09:15:23'::timestamp) ;     
date_part 
-----------
         7
(1 row)

isoyear: ISO 标准的年 : (

ISO标准的纪年是从周一开始,以一月4号之前的周一为新的纪年的开始,跟公元纪年有区别,所以一年的一月份的前几天,或者12月的后几天可能会跟公元纪年法有区别:

postgres=# select extract(isoyear from '2013-01-01'::date) ; 
date_part 
-----------
      2013
(1 row)

postgres=# select extract(isoyear from '2012-12-31'::date) ;     
date_part 
-----------
      2013
(1 row)

postgres=# select extract(isoyear from '2012-12-30'::date) ;     
date_part 
-----------
      2012
(1 row)

postgres=# select extract(dow from '2012-12-31'::date) ;     
date_part 
-----------
         1
(1 row)

microseconds: 微秒

用微秒标识的 秒 的部分,包括后面小数部分:

postgres=# select  extract(microseconds from interval '3 days 5 mins 3.5 sec') ;
date_part 
-----------
   3500000
(1 row)

postgres=# select extract(microseconds from '2013-07-21 09:15:23'::timestamp)   
postgres-# ;
date_part 
-----------
  23000000
(1 row)

millennium  : 千禧年 ,千年纪年

目前是21世纪,第3个千禧年

postgres=# select extract(millennium from '2013-07-21 09:15:23'::timestamp) ;              
date_part 
-----------
         3
(1 row)

minute: 分钟(0-59) 

postgres=# select extract(minute from '2013-07-21 09:15:23'::timestamp) ;           
date_part 
-----------
        15
(1 row)

month : 月份   对timestamp 类型 返回1-12, 对interval 类型返回0-11

postgres=# select extract(month  from '2013-07-21 09:15:23'::timestamp) ;       
date_part 
-----------
         7
(1 row)

postgres=# select extract(month  from  interval ' 7 months 5 days' ) ;                                 
date_part 
-----------
         7
(1 row)

postgres=# select extract(month  from  interval '  5 days' ) ;  
date_part 
-----------
         0
(1 row)

postgres=# select extract(month  from  interval ' 12 months 5 days' ) ;    
date_part 
-----------
         0
(1 row)

postgres=# select extract(month  from  interval ' 11 months 5 days' ) ;   
date_part 
-----------
        11
(1 row)

quarter : 季度 

postgres=# select extract(quarter  from '2013-07-21 09:15:23'::timestamp) ;               
date_part 
-----------
         3
(1 row)

postgres=# select extract(quarter  from '2013-06-21 09:15:23'::timestamp) ;  
date_part 
-----------
         2
(1 row)

second : 秒 (0-59)

postgres=# select extract(second  from '2013-06-21 09:15:23'::timestamp) ;        
date_part 
-----------
        23
(1 row)

week :  周记 

postgres=# select extract(week   from '2013-06-21 09:15:23'::timestamp) ;         
date_part 
-----------
        25
(1 row)

year: 年纪 

postgres=# select extract(year   from '2013-06-21 09:15:23'::timestamp) ;     
date_part 
-----------
      2013
(1 row)

PG extract 函数示例的更多相关文章

  1. Format 函数示例

    Format 函数示例本示例显示用 Format 函数做格式化输出的不同用法.对于日期分隔号(/),时间分隔号(:),以及 AM/ PM 等文本而言,其真正的显示格式会因计算机上的国际标准不同而有所差 ...

  2. php extract 函数的妙用 数组键名为声明为变量,键值赋值为变量内容

    extract 函数的妙用 数组键名为声明为变量,键值赋值为变量内容 它的主要作用是将数组展开,键名作为变量名,元素值为变量值,可以说为数组的操作提供了另外一个方便的工具

  3. ThinkPHP邮件发送函数示例

    ThinkPHP邮件发送函数示例详解 /** * 发送邮件 * @param $tomail * @param $subject * @param $body * @param string $con ...

  4. PHP extract() 函数

    PHP extract() 函数从数组中把变量导入到当前的符号表中. 对于数组中的每个元素,键名用于变量名,键值用于变量值. 第二个参数 type 用于指定当某个变量已经存在,而数组中又有同名元素时, ...

  5. (转)PHP中extract()函数的妙用

    近日在看一个牛人的代码时,看到一个非常好用的函数:extract(),它的主要作用是将数组展开,键名作为变量名,元素值为变量值,可以说为数组的操作提供了另外一个方便的工具,比方说,可以很方便的提取$_ ...

  6. (转)PHP中extract()函数的妙用

    近日在看一个牛人的代码时,看到一个非常好用的函数:extract(),它的主要作用是将数组展开,键名作为变量名,元素值为变量值,可以说为数组的操作提供了另外一个方便的工具,比方说,可以很方便的提取$_ ...

  7. 数据分析与展示——Matplotlib基础绘图函数示例

    Matplotlib库入门 Matplotlib基础绘图函数示例 pyplot基础图表函数概述 函数 说明 plt.plot(x,y,fmt, ...) 绘制一个坐标图 plt.boxplot(dat ...

  8. MySQL EXTRACT() 函数

    定义和用法 EXTRACT() 函数用于返回日期/时间的单独部分,比如年.月.日.小时.分钟等等. 语法 EXTRACT(unit FROM date) date 参数是合法的日期表达式.unit 参 ...

  9. python3使用ctypes在windows中访问C和C++动态链接库函数示例

    python3使用ctypes在windows中访问C和C++动态链接库函数示例 这是我们的第一个示例,我们尽量简单,不传参,不返回,不访问其他的动态链接库 一 测试环境介绍和准备 测试环境: 操作系 ...

随机推荐

  1. 【旧文章搬运】从XP到Win7看Windows对象管理的变化(概述)

    原文发表于百度空间,2010-08-01========================================================================== 今天花了一 ...

  2. HDFS源码分析三-DataNode实现

    3. DataNode 实现( 未完待续 )

  3. 接口开发之PHP创建XML文件

    用PHP的DOM控件来创建输出 输出的格式为XML 接口开发的相关文件及说明 <?php header("Content-type: text/xml");//头文件非常重要 ...

  4. Linux 软链接 硬链接 ln命令(繁杂版)

    注意:创建软连接的时候,要用绝对路径!!! 这是linux中一个非常重要命令,请大家一定要熟悉.它的功能是为某一个文件在另外一个位置建立一个同不的链接,这个命令最常用的参数是-s,具体用法是:ln - ...

  5. Android 4.2开发环境搭建

    一.工具 jdk1.7; eclipse 4.3(for java ee); Android SDK; 二.安装JDK并配置 安装略,配置如下: 右击 “我的电脑”->属性->高级系统设置 ...

  6. 服务器无法在发送 HTTP 标头之后修改 cookie

    隔三差五就碰到VS报错: System.Web.HttpException:“服务器无法在发送 HTTP 标头之后修改 cookie.” 解决后过几天又忘记了. 原因是: 程序为每个页面在config ...

  7. layui icon样式1到7

    1: 2: 3: 4: 5: 6: 7:

  8. Bloomberg 的一些功能

    FFLO: 查看ETF流动,注意在View点击Contries后选择Asia,查看亚洲流动. 随后对感兴趣的国家点击查看具体股票的流动 关闭Launchpad View之后再次打开: BLP 修改La ...

  9. Python 实现简单的登录注册界面

    Python 实现简单的登录注册界面 注意:编写代码之前需要导入很重要的包 import tkinter as tk import pickle from tkinter import message ...

  10. Eclipse mybatis中XML的自动提示

    1. 从mybatis-3.1.1.jar中解压出dtd文件 2. 3. 复制红线处内容 4. 将上步中内容粘贴到key中