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. CS231n 2016 通关 第三章-SVM 作业分析

    作业内容,完成作业便可熟悉如下内容: cell 1  设置绘图默认参数 # Run some setup code for this notebook. import random import nu ...

  2. AspNetPager样式以及属性帮助文档

    帮助文档地址:http://www.webdiyer.com/AspNetPagerDocs/index.html 应用样式:http://www.webdiyer.com/AspNetPagerDe ...

  3. MSSQL 调用 .net 代码

    http://www.cnblogs.com/laozhao8/p/3398681.html 在SQL Server中调用.NET程序集   需求是这样的,我在.net程序里操作数据时将一些字段数据加 ...

  4. 菜鸟-@responsebody 理解-用法

    @responsebody表示该方法的返回结果直接写入HTTP response body中一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上@respo ...

  5. Flutter实战视频-移动电商-62.购物车_首页Provide化 让跳转随心所欲

    62.购物车_首页Provide化 让跳转随心所欲 新建provide/currentIndex.dart 内容比较简单,定义一个变量当前页面的索引currentIndex,再定义一个方法改变它的值 ...

  6. MyBatis中的RowBounds

    myBatis中实现分页的方式是采用RowBounds这个类,用法如下,xml语句不变 传入两个参数,strat起始行, limit是当前页显示多少条数据,原理是RowBounds在处理分页时,只是简 ...

  7. 新装centos 6.5 基本配置

    开机自动联网 vi /etc/sysconfig/network-scripts/ifcfg-eth0; 将ONBOOT=no,改为ONBOOT=yes,保存退出 开机直接进入命令行模式 vi /et ...

  8. CF446B DZY Loves Modification 【思维/优先队列】By cellur925

    题目传送门 题目大意:给一个 \(n*m\) 的矩阵,并进行 \(k\) 次操作,每次操作将矩阵的一行或一列的所有元素的值减 \(p\) ,得到的分数为这次修改之前这一列/一行的元素和,求分数最大值. ...

  9. Elasticsearch and MongoDb

    http://www.linkedin.com/groups/Difference-between-elasticsearch-MongoDB-3393294.S.588764405916973056 ...

  10. 基于PHP的正则表达式

    用法 从某个字符抽取信息 用新文本替换匹配的文本 把字符串拆分成小块字符串组成的数组 基础 preg_match('/需要匹配的正则表达式/', '字符串'); 正则匹配模式 集合: [xxxx]-- ...