postgresql踩坑系列之关于to_date()问题

 更新时间:2023年03月21日 08:55:43   作者:Sokasa_BiuBiuBiu  
这篇文章主要介绍了postgresql踩坑系列之关于to_date()问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

postgresql关于to_date()问题

这里是对postgresql 使用时踩的坑的记录

上图来一波官方文档

官方文档地址 : https://www.postgresql.org/docs/8.1/functions-formatting.html

PostgreSQL文档地址 https://www.postgresql.org/docs/8.1/functions-formatting.html

1.to_date(text,text), 在PostgreSQL 里 也是将字符串转换成日期, 但是 仅仅是年月日部分,就算我们在方法里指定了格式亦是如此

比如:

select to_date('2019-01-15 18:33:41','yyyy-MM-dd hh24:mi:ss');

结果就是

2019-01-15

没看错,就是这玩意。因此如果在项目里使用 这函数去对日期操作,比如 查询某日某时某点某秒之前的访问数据量,当入参正确,那么计算很有可能是错误的。因为时分秒 没了,会自动隐式转换成 2019-01-15 00:00:00。和这数据比较,那么15号这天的数据都是不存在的。

而正确的使用姿势应该是:

select to_timestamp('2019-01-15 18:33:41','yyyy-MM-dd hh24:mi:ss')

结果就是

2019-01-15 18:33:41+00

后面的+00 就是计算时区的意思,00不计算。 这方法就是将字符串按照指定格式转换成不带时区(timestamp with time zone)的日期。

因此,在使用PostgreSQL进行日期相关操作的时候如果没有特殊要求尽量使用to_timestamp(text,text) 方法去进行操作。

postgresql中to_date()函数使用

问题

错误:数 to_date(timestamp without time zone, unknown) 不存在 Hint: 没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换.

原来的使用方式是:

to_date(createddate,'YYYY-MM-DD')  

解决方式

方法一:

to_date(createddate::text,'YYYY-MM-DD')  

**方法二:**

to_date(cast(createddate as TEXT),'YYYY-MM-DD') 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • PostgreSQL中Slony-I同步复制部署教程

    PostgreSQL中Slony-I同步复制部署教程

    这篇文章主要给大家介绍了关于PostgreSQL中Slony-I同步复制部署的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用PostgreSQL具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-06-06
  • Postgresql 通过出生日期获取年龄的操作

    Postgresql 通过出生日期获取年龄的操作

    这篇文章主要介绍了Postgresql 通过出生日期获取年龄的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • postgreSQL中的内连接和外连接实现操作

    postgreSQL中的内连接和外连接实现操作

    这篇文章主要介绍了postgreSQL中的内连接和外连接实现操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • postgreSQL使用pgAdmin备份服务器数据的方法

    postgreSQL使用pgAdmin备份服务器数据的方法

    这篇文章主要介绍了postgreSQL使用pgAdmin备份服务器数据的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • PostgreSQL 查看数据库,索引,表,表空间大小的示例代码

    PostgreSQL 查看数据库,索引,表,表空间大小的示例代码

    PostgreSQL 提供了多个系统管理函数来查看表,索引,表空间及数据库的大小,下面详细介绍一下
    2013-08-08
  • PostgreSQL逻辑复制解密原理解析

    PostgreSQL逻辑复制解密原理解析

    逻辑复制,是基于复制标识复制数据及其变化的一种方法,区别于物理复制对页面操作的描述,逻辑复制是对事务及数据元组的一种描述,这篇文章主要介绍了PostgreSQL逻辑复制解密原理解析,需要的朋友可以参考下
    2022-09-09
  • postgresql中的ltree类型使用方法

    postgresql中的ltree类型使用方法

    这篇文章主要给大家介绍了关于postgresql中ltree类型使用的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用postgresql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • Postgresql 数据库转义字符操作

    Postgresql 数据库转义字符操作

    这篇文章主要介绍了Postgresql 数据库转义字符操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL教程(二十):PL/pgSQL过程语言

    PostgreSQL教程(二十):PL/pgSQL过程语言

    这篇文章主要介绍了PostgreSQL教程(二十):PL/pgSQL过程语言,本文讲解了、PL/pgSQL概述、PL/pgSQL的结构、声明、基本语句、控制结构等内容,需要的朋友可以参考下
    2015-05-05
  • PostgreSQL关闭数据库服务的三种模式

    PostgreSQL关闭数据库服务的三种模式

    PostgreSQL 提供了三种关闭数据库服务的不同方式,它们最终都是发送一个关闭信号到 postgres 主服务进程,本文将给大家详细的介绍一下这三种模式,需要的朋友可以参考下
    2024-07-07

最新评论