PG extract 函数示例
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 函数示例的更多相关文章
- Format 函数示例
Format 函数示例本示例显示用 Format 函数做格式化输出的不同用法.对于日期分隔号(/),时间分隔号(:),以及 AM/ PM 等文本而言,其真正的显示格式会因计算机上的国际标准不同而有所差 ...
- php extract 函数的妙用 数组键名为声明为变量,键值赋值为变量内容
extract 函数的妙用 数组键名为声明为变量,键值赋值为变量内容 它的主要作用是将数组展开,键名作为变量名,元素值为变量值,可以说为数组的操作提供了另外一个方便的工具
- ThinkPHP邮件发送函数示例
ThinkPHP邮件发送函数示例详解 /** * 发送邮件 * @param $tomail * @param $subject * @param $body * @param string $con ...
- PHP extract() 函数
PHP extract() 函数从数组中把变量导入到当前的符号表中. 对于数组中的每个元素,键名用于变量名,键值用于变量值. 第二个参数 type 用于指定当某个变量已经存在,而数组中又有同名元素时, ...
- (转)PHP中extract()函数的妙用
近日在看一个牛人的代码时,看到一个非常好用的函数:extract(),它的主要作用是将数组展开,键名作为变量名,元素值为变量值,可以说为数组的操作提供了另外一个方便的工具,比方说,可以很方便的提取$_ ...
- (转)PHP中extract()函数的妙用
近日在看一个牛人的代码时,看到一个非常好用的函数:extract(),它的主要作用是将数组展开,键名作为变量名,元素值为变量值,可以说为数组的操作提供了另外一个方便的工具,比方说,可以很方便的提取$_ ...
- 数据分析与展示——Matplotlib基础绘图函数示例
Matplotlib库入门 Matplotlib基础绘图函数示例 pyplot基础图表函数概述 函数 说明 plt.plot(x,y,fmt, ...) 绘制一个坐标图 plt.boxplot(dat ...
- MySQL EXTRACT() 函数
定义和用法 EXTRACT() 函数用于返回日期/时间的单独部分,比如年.月.日.小时.分钟等等. 语法 EXTRACT(unit FROM date) date 参数是合法的日期表达式.unit 参 ...
- python3使用ctypes在windows中访问C和C++动态链接库函数示例
python3使用ctypes在windows中访问C和C++动态链接库函数示例 这是我们的第一个示例,我们尽量简单,不传参,不返回,不访问其他的动态链接库 一 测试环境介绍和准备 测试环境: 操作系 ...
随机推荐
- bzoj3168
二分图+矩阵求逆 既然我们考虑b能替换哪些a,那么我们自然要得出b被哪些a表示,这里我们设一个矩阵C,那么C*A = B 为什么呢?直接A*C = B是不可行的,因为都是行向量,不能直接乘,那么我们转 ...
- XAMPP打不开Apache服务的解决办法
XAMPP打不开Apache服务的解决办法 不用修改设置,应该是80端口被占用了,直接先IIS的网站给停了就OK
- SQL Server 盛宴系列 webcast
数据库学习站点,示例,视频 http://technet.microsoft.com/zh-cn/dd722671.aspx
- E20190226-hm
shallow adj. 浅的,肤浅的; 表面的,皮毛的; (水,器物等) 浅的; (呼吸) 浅的; n. 浅处; 浅滩;
- 序列化框架MJExtension详解 + iOS ORM框架
当开发中你的模型中属性名称和 字典(JSON/XML) 中的key 不能一一对应时, 或者当字典中嵌套了多层字典数组时..., 以及教你如何用 MJExtension 配置类来统一管理你的模型配置, ...
- lightoj 1078【同余定理】
题意: 给你一个n和一个数 digit ,问你最少需要多少个 digit 使得整除于n; 思路: 同余定理(a+b)%n=(a%n+b%n)%n; (m%n+m%n*10+m%n*100+m%n*10 ...
- POJ 3067【树状数组】
题意: 给你两行数字,n个m个,然后给你k条线直接把两个数连起来,问有多少个交叉的 思路: 假定上一行是起点,下一行是终点. 把路按照起点从大到下排序, 然后可以直接对每条路查询,这条路目前的交叉数, ...
- 3d工具收集
Poser 是Metacreations公司推出的一款三维动物.人体造型和三维人体动画制作的极品软件.用过Poser 2与Poser 3的朋友一定能感受到Poser的人体设计和动画制作是那么的轻松自如 ...
- C#:索引
1. 什么是索引 索引是一组get和set访问器,类似于属性的访问器. 2. 索引和属性 和属性一样,索引不用分配内存来存储 索引和属性都主要被用来访问其他数据成员,这些成员和它们关联,它们为这些成员 ...
- Windows下SVN的下载、安装
SVN全称Subversion,是一款优秀的版本控制工具. SVN分为服务器.客户端两部分,服务器和客户端版本很多,有的是收费的,有的需要注册.我们选择免费.不用注册的. 以VisualSVN作为服务 ...