PostgreSQL 数据类型转换

文章介绍了在数据库操作中如何进行日期/时间、整型、浮点数、数值型数据与字符串之间的转换,包括to_char、to_date、to_timestamp和to_number等函数的使用,以及字符串的替换和截取方法。这些转换在实际数据库管理和数据分析中非常常见。

各种数据类型(日期/时间、integer、floating point和numeric)转换成格式化的字符串及反过来从格式化的字符串转换成指定的数据类型,在实际操作中经常遇到。下面总结了一些常用的函数。

日期操作函数

函数返回类型描述实例
to_char(timestamp,text)text把时间间隔转换为字符串to_char(current_timestamp,"HH12:MI:SS")
to_char(interval,text)text把时间间隔转换为字串to_char(interval'15h 12m 12s','HH24:MI:SS')
to_char(int,text)text把整型转换为字串to_char(125,'999')
to_char(double,precision)text把实数/双精度数转换为字串to_char(125.8::real,'999D9')
to_char(numeric,text)text把numeric转换为字串to_char(-125.8,'999D99S')
to_date(text,text)date把字串转换为日期to_date('05 Dec 2000','DD Mon YYYY')
to_timetamp(text,text)timestamp把字串转换为时间戳to_timestamp('05 Dec 2000','DD Mon YYYY'
to_timetamp(double)timestamp把unix纪元转换为时间戳to_timestamp(200120400)
to_number(text,text)numeric把字串转换为numericto_number('12 454.8-','99G999D9S'

用于日期/时间格式化的模式

模式描述
HH一天的小时数(01-12)
HH12一天的小时数(01-12)
HH24一天的小时数(00-23)
MI分钟(00-59)
SS秒(00-59)
MS毫秒(000-999)
US微秒(000000-999999)
AM正午标识(大写)
Y,YYY带逗号的年(4和更多位)
YYYY年(4和更多位)
YYY年的后三位

字符串转换为整型

* 把'12345' 转换为整数
select cast ('12345' as integer);
* 用substring截取字符串,从第8个字符开始截取2个字符
select cast (substring('123344654',8,2) as integer);

替换字符串方法及字符串操作函数

  • 替换字符串实例
* 把字段coulmn_name里的字符"aaa"替换为'0'
update table_name set coulmn_name=replace(a,"aaa","0");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值