热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

PostgreSQL时间日期函数的使用介绍

PostgreSQL的常用时间函数使用整理如下:一、获取系统时间函数1.1获取当前完整时间selectnow();david#selectnow();now---------------------------------::40.399711+(row)david#current_timestamp同now()函数等

PostgreSQL的常用时间函数使用整理如下:

一、获取系统时间函数

1.1 获取当前完整时间

select now();


david=# select now();
              now
-------------------------------
 -- ::40.399711+
( row)

david=#

current_timestamp 同 now() 函数等效。


david=# select current_timestamp;
              now
-------------------------------
 -- ::22.398709+
( row)

david=#

1.2 获取当前日期

select current_date;


david=# select current_date;
    date
------------
 --
( row)

david=#

1.3 获取当前时间

select current_time;


david=# select current_time;
       timetz
--------------------
 ::31.101726+
( row)

david=#

二、时间的计算


david=# select now();
              now
-------------------------------
 -- ::13.244721+
( row)

david=#

2.1 两年后


david=# select now() + interval '2 years';
           ?column?
-------------------------------
 -- ::03.168851+
( row)

david=# select now() + interval '2 year';
           ?column?
-------------------------------
 -- ::12.378727+
( row)

david=# select now() + interval '2 y';
           ?column?
------------------------------
 -- ::25.46986+
( row)

david=# select now() + interval '2 Y';
           ?column?
-------------------------------
 -- ::28.410853+
( row)

david=# select now() + interval '2Y';
           ?column?
-------------------------------
 -- ::31.122831+
( row)

david=#

2.2 一个月后


david=# select now() + interval '1 month';
           ?column?
------------------------------
 -- ::22.24373+
( row)

david=# select now() + interval 'one month';
ERROR:  invalid input syntax for type interval: "one month"
LINE : select now() + interval 'one month';
                                ^
david=#

2.3 三周前


david=# select now() - interval '3 week';
           ?column?
-------------------------------
 -- ::04.203735+
( row)

david=#

2.4 十分钟后


david=# select now() + '10 min';
           ?column?
-------------------------------
 -- ::47.445744+
( row)

david=#

说明:

interval 可以不写,其值可以是:

Abbreviation Meaning
Y Years
M Months (in the date part)
W Weeks
D Days
H Hours
M Minutes (in the time part)
S Seconds

 

 

 

 

 

2.5 计算两个时间差

使用 age(timestamp, timestamp)


david=# select age(now(), timestamp '1989-02-05');
                  age
----------------------------------------
  years  mons  days ::49.119848
( row)

david=#


david=# select age(timestamp '2007-09-15');
          age
------------------------
  years  mons  days
( row)

david=#

三、时间字段的截取

在开发过程中,经常要取日期的年,月,日,小时等值,PostgreSQL 提供一个非常便利的EXTRACT函数。


EXTRACT(field FROM source)

field 表示取的时间对象,source 表示取的日期来源,类型为 timestamp、time 或 interval。

3.1 取年份


david=# select extract(year from now());
 date_part
-----------
      
( row)

david=#

3.2 取月份


david=# select extract(month from now());
 date_part
-----------
         
( row)

david=#


david=# select extract(day from timestamp '2013-04-13');
 date_part
-----------
        
( row)

david=#


david=# SELECT EXTRACT(DAY FROM INTERVAL '40 days 1 minute');
 date_part
-----------
        
( row)

david=#

3.3 查看今天是一年中的第几天


david=# select extract(doy from now());
 date_part
-----------
       
( row)

david=#

3.4 查看现在距1970-01-01 00:00:00 UTC 的秒数


david=# select extract(epoch from now());
    date_part
------------------
 1365755907.94474
( row)

david=#

3.5 把epoch 值转换回时间戳


david=# SELECT TIMESTAMP WITH TIME ZONE 'epoch' +  * INTERVAL '1 second';
        ?column?
------------------------
 -- ::+
( row)

david=#

以上是基本的PG时间/日期函数使用,可满足一般的开发运维应用。

 


推荐阅读
  • 本文介绍了MySQL窗口函数的基本概念、应用场景及常见函数的使用方法。窗口函数在处理复杂查询时非常有用,例如计算每个用户的订单排名、环比增长率、以及动态聚合等。 ... [详细]
  • 本文介绍了如何在 Oracle 数据库中查询重复数据,并提供了多种方法来筛选和删除重复记录,包括基于单个字段和多个字段的重复数据处理。 ... [详细]
  • 七大策略降低云上MySQL成本
    在全球经济放缓和通胀压力下,降低云环境中MySQL数据库的运行成本成为企业关注的重点。本文提供了一系列实用技巧,旨在帮助企业有效控制成本,同时保持高效运作。 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 在中标麒麟操作系统上部署达梦数据库及导入SQL文件
    本文档详细介绍了如何在中标麒麟操作系统上安装达梦数据库,并提供了导入SQL文件的具体步骤。首先,检查系统的发行版和内核版本,接着创建必要的用户和用户组,规划数据库安装路径,挂载安装介质,调整系统限制以确保数据库的正常运行,最后通过图形界面完成数据库的安装。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文介绍了如何通过安装 sqlacodegen 和 pymysql 来根据现有的 MySQL 数据库自动生成 ORM 的模型文件(model.py)。此方法适用于需要快速搭建项目模型层的情况。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • 探讨在使用 PL/SQL Developer 12.0 的数据生成器时遇到的中文乱码问题及其解决方案。 ... [详细]
  • 软件测试行业深度解析:迈向高薪的必经之路
    本文深入探讨了软件测试行业的发展现状及未来趋势,旨在帮助有志于在该领域取得高薪的技术人员明确职业方向和发展路径。 ... [详细]
  • 本文介绍了一种使用SQL Server存储过程来实现基于单一条件的高效分页查询的方法。通过示例代码,详细说明了如何构建和执行这种分页查询。 ... [详细]
  • 如何在Django框架中实现对象关系映射(ORM)
    本文介绍了Django框架中对象关系映射(ORM)的实现方式,通过ORM,开发者可以通过定义模型类来间接操作数据库表,从而简化数据库操作流程,提高开发效率。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
author-avatar
集束群
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有