Postgresql数据类型-时间类型

news2024/11/25 11:23:59

PostgreSQL对时间、日期数据类型的支持丰富而灵活,本节介绍PostgreSQL支持的时间、日期类型,及其操作符和常用函数。

PostgreSQL支持的时间、日期类型如表所示。

我们通过一个简单的例子理解这几个时间、日期数据类型,先来看看系统自带的now()函数,now()函数显示当前时间,返回的类型为timestamp [ (p) ] with time zone,如下所示:

        mydb=> SELECT now();
                      now
        -------------------------------
          2017-07-29 09:44:25.493425+08
        (1 row)

 这里提前介绍下类型转换,本章最后一节将专门介绍数据类型转换的常用方法,以下SQL中的两个冒号是指类型转换,转换成timestamp without time zone格式如下,注意返回的数据变化:

        mydb=> SELECT now()::timestamp without time zone;
                      now
        ----------------------------
            2017-07-29 09:44:55.804403
        (1 row)

转换成date格式,如下所示:

        mydb=> SELECT now()::date;
            now
        ------------
          2017-07-29
        (1 row)

转换成time without time zone,如下所示:

        mydb=> SELECT now()::time without time zone;
            now
        -----------------
        09:45:49.390428
        (1 row)

interval指时间间隔,时间间隔单位可以是hour、day、month、year等,举例如下:

        mydb=> SELECT now(), now()+interval'1 day';
                          now               |           ? column?
        ----------------------------------+-------------------------------
          2017-07-29 09:47:26.026418+08 | 2017-07-30 09:47:26.026418+08
        (1 row)

通过以上几个示例读者应该对时间、日期数据类型有了初步的了解,值得一提的是时间类型中的(p)是指时间精度,具体指秒后面小数点保留的位数,如果没声明精度默认值为6,以下示例声明精度为0:

        mydb=> SELECT now(), now()::timestamp(0);
                          now               |         now
        ----------------------------------+---------------------
          2017-07-29 09:59:42.688445+08 | 2017-07-29 09:59:43
        (1 row)

时间、日期数据类型支持的操作符有加、减、乘、除,下面举例说明。日期相加,如下所示:

        mydb=> SELECT date '2017-07-29' +  interval'1 days';
                ?column?
        ---------------------
            2017-07-30 00:00:00
        (1 row)

日期相减,如下所示:

        mydb=> SELECT date '2017-07-29' -  interval'1 hour';
                ?column?
        ---------------------
            2017-07-28 23:00:00
        (1 row)

日期相乘,如下所示:

        mydb=> SELECT 100* interval '1 second';
            ?column?
        ----------
            00:01:40
        (1 row)

日期相除,如下所示:

        mydb=> SELECT interval '1 hour' / double precision '3';
            ?column?
        ----------
            00:20:00
        (1 row)

接下来演示时间、日期常用函数。显示当前时间,如下所示:

        mydb=> SELECT current_date, current_time;
            current_date |    current_time
        -----------------+--------------------
            2017-07-29   | 10:53:10.375374+08
        (1 row)

另一个非常重要的函数为EXTRACT函数,可以从日期、时间数据类型中抽取年、月、日、时、分、秒信息,语法如下所示:

        EXTRACT(field FROM source)

field值可以为century、year、month、day、hour、minute、second等,source类型为timestamp、time、interval的值的表达式,例如取年份,代码如下所示:

        mydb=> SELECT EXTRACT( year FROM now());
            date_part
        -----------
                2017
        (1 row)

对于timestamp类型,取月份和月份里的第几天,代码如下所示:

        mydb=> SELECT EXTRACT( month FROM now()), EXTRACT(day FROM now());
            date_part | date_part
        --------------+-----------
                    7 |        29
        (1 row)

取小时、分钟,如下所示:

        mydb=> SELECT EXTRACT( hour FROM now()), extract (minute FROM now());
            date_part | date_part
        --------------+-----------
                    11 |        14

取秒,如下所示:

        mydb=> SELECT EXTRACT( second FROM now());
            date_part
        -----------
            43.031366
        (1 row)

取当前日期所在年份中的第几周,如下所示:

        mydb=> SELECT EXTRACT( week FROM now());
            date_part
        -----------
                30
        (1 row)

当天属于当年的第几天,如下所示:

        mydb=> SELECT EXTRACT( doy FROM now());
            date_part
        -----------
                210
        (1 row)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1191158.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

高性能网络编程 - 解读5种I/O模型

文章目录 服务端处理网络请求流程图基础概念阻塞调用 vs 非阻塞调用同步处理 vs 异步处理阻塞、非阻塞 和 同步、异步的区别recvfrom 函数 五种I/O模型I/O模型1:阻塞式 I/O 模型(blocking I/O)I/O模型2:非阻塞式 I/O 模型(non-blocking I/O&a…

实用技巧:嵌入式人员使用http服务模拟工具模拟http服务器测试客户端get和post请求

文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/134305752 红胖子(红模仿)的博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬结…

卡尔曼滤波EKF

目录 一、概述 二、卡尔曼滤波的5个公式 三、应用案例:汽车运动 四、应用案例:温度估计 五、总结 一、概述 初学者对于卡尔曼滤波5个公式有点懵,本文先接地气地介绍5个公式,然后举两个常用例子加强理解,同时附有M…

杰里6969系列控制RGB彩灯模式

1、任务目标 实现可以接收到APP传输过来的数据,可以通过传输的数据前几个字节识别到所需要控制的模式,然后提取数据的后几个字节来分别对RGB灯进行不同的的PWM波控制,从而实现跳变和渐变的效果。 2.跳变(分布调试记录&#xff09…

创建多层级行索引,创建多层级行索引的DataFrameMultiIndex.from_product()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 创建多层级行索引, 创建多层级行索引的DataFrame MultiIndex.from_product() [太阳]选择题 使用pd.MultiIndex.from_product(),下列输出正确的是: import pandas as pd…

一键批量删除文件名中的空格,高效整理您的文件

你是否曾经因为文件名中多余的空格而烦恼?这些空格不仅影响了文件的美观,还可能导致一些不必要的错误。现在,我们向您介绍一款全新的工具,它可以帮助您一键批量删除文件名中的空格,让您的文件整理更加轻松、高效&#…

一款功能强大的web目录扫描器专业版

dirpro 简介 dirpro 是一款由 python 编写的目录扫描器,操作简单,功能强大,高度自动化。 自动根据返回状态码和返回长度,对扫描结果进行二次整理和判断,准确性非常高。 已实现功能 可自定义扫描线程 导入url文件进…

劲松中西医医院专家谭巍医生解读:生殖衣原体阳性是什么意思

生殖衣原体阳性是指生殖系统出现了衣原体感染。衣原体是我们身体中常见的菌群,生殖系统常见的衣原体有:沙眼衣原体,当然还包括一些支原体,如:人型支原体、解脲支原体等,都可引起生殖系统出现一系列的感染症…

华为L410上制作内网镜像模板02

原文链接:华为L410上制作离线安装软件模板02 hello,大家好啊,今天给大家带来第二篇在内网搭建Apache服务器,用于安装完内网操作系统后,在第一次开机时候,为系统安装软件的文章,今天给大家介绍在…

Linux常见指令:从基础到理论

前言 目录 前言 1. find指令 拓展 2. grep指令 拓展 sort指令 uniq指令 wc指令 3. zip/unzip指令 4. tar指令 5. uname指令 拓展 6. Linux常用热键 7. 关机 8. rz指令 拓展 scp指令 9. shell命令以及运行原理 Linux常见指令是使用Linux系统时必不可少的一部分。通过掌握…

【QML】Qt和QML获取操作系统类型

1. Qt获取系统类型 //方法 QSysInfo::productType()//举例&#xff1a; if(QSysInfo::productType() "windows") {qDebug() << "windows system"; }官方说明&#xff1a; [static] QString QSysInfo::productType() Returns the product name of …

【数据结构】树与二叉树(七):二叉树的遍历

文章目录 5.1 树的基本概念5.1.1 树的定义5.1.2 森林的定义5.1.3 树的术语5.1.4 树的表示 5.2 二叉树5.2.1 二叉树1. 定义2. 特点3. 性质引理5.1&#xff1a;二叉树中层数为i的结点至多有 2 i 2^i 2i个&#xff0c;其中 i ≥ 0 i \geq 0 i≥0。引理5.2&#xff1a;高度为k的二叉…

MySQL -- 事务管理

MySQL – 事务管理 文章目录 MySQL -- 事务管理一、理解事务1.如果CURD不加控制&#xff0c;会有什么问题2.事务的概念 二、MySQL中的事务1.事务的版本支持2.事务提交方式3.事务常见操作方式3.1.事务的开始与回滚3.2.证明未commit&#xff0c;客户端崩溃&#xff0c;MySQL自动会…

Vue脚手架学习笔记

视频 Vue脚手架学习笔记 1. 脚手架设置相关内容1.1 各文件的作用1.2 关闭语法检查 2. 组件的使用2.1 单文件组件的使用&#xff08;组件使用的三个步骤&#xff09;2.2 prop配置项&#xff1a;父向子传数据2.2.1 数组方式2.2.2 类型限制2.2.3 默认值、必要性 2.3 ref &#xf…

C# OpenCvSharp 玉米粒计数

效果 项目 代码 using OpenCvSharp; using System; using System.Drawing; using System.Text; using System.Windows.Forms;namespace OpenCvSharp_Demo {public partial class frmMain : Form{public frmMain(){InitializeComponent();}string fileFilter "*.*|*.bmp;…

2023年CCF非专业级别软件能力认证第二轮 (CSP-S)提高级C++语言试题

2023年CCF非专业级别软件能力认证第二轮 &#xff08;CSP-S&#xff09;提高级C语言试题 编程题第 1 题 问答题 密码锁&#xff08;lock&#xff09; 题目描述 小Y有一把五个拨圈的密码锁。如图所示&#xff0c;每个拨圈上是从0到9的数字。每个拨圈都是从0到9的循环&#xf…

【算法 | 模拟No.4】AcWing 756. 蛇形矩阵 AcWing 40. 顺时针打印矩阵

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【AcWing算法提高学习专栏】 &#x1f354;本专栏旨在提高自己算法能力的同时&#xff0c;记录一下自己的学习过程&a…

汉诺塔 --- 递归回溯算法练习一

目录 1. 什么叫汉诺塔 2. 分析算法原理 2.1. 当盘子的数量为1 2.2. 当盘子的数量为2 2.3. 当盘子的数量为3时 3. 编写代码 3.1. 挖掘重复子问题 3.2. 只关心某一个子问题如何处理 3.3. 递归的结束条件 3.4. 代码的编写 4. 递归展开图分析 1. 什么叫汉诺塔 力扣上的原…

Go并发编程(上)

目录 一、go语言当中的协程 二、MPG模型介绍 三、Goroutine 的使用 3.1 协程的开启 3.2 优雅地等待子协程结束 四、捕获子协程的panic 五、管道Channel 5.1、认识管道 5.2、Channel的遍历和关闭 5.3 、用管道实现生产者消费者模型 5.4、Channel一些使用细节和注意事…

揭秘!2024年热门的图标设计工具

在这个瞬息万变的世界里&#xff0c;设计师们对创新和实用的工具的渴望日益热切。我们需要时刻紧跟潮流&#xff0c;发掘和尝试最新&#xff0c;最有价值的图标设计工具&#xff0c;才能在剧烈的市场竞争中引人注目。以下是我们细心挑选的2024年图标设计工具的热门推荐&#xf…