5.pgsql类型转换

本文详细介绍了 PostgreSQL 中不同类型转换的规则和实例,包括指数运算、字符串连接、绝对值和取反、圆整函数、子字符串操作以及值存储时的数据类型解析。分析器会根据操作符和函数的要求进行类型转换,例如将未知类型转换为字符串或数值类型,以及在存储时确保数据长度符合目标列的定义。
摘要由CSDN通过智能技术生成

-- 1.在系统表中里只有一个指数操作符,它以 double precision 作为参数。

-- 扫描器给下面查询表达式的两个参数赋予 integer 的初始类型:
SELECT 2 ^ 3 AS "exp";
-- 分析器对两个参数都做类型转换,查询等效于:
SELECT CAST(2 AS double precision) ^ CAST(3 AS double precision) AS "exp";

-- 2.字符串连接操作符类型分析
-- 一种字符串风格的语法既可以用于字符串也可以用于复杂的扩展类型。未声明类型的字符串将被所有可能的候选操作符匹配。
SELECT 'abc'::text || 'def' AS "text and unknown";
-- 因为查询中没有声明任何类型,所以本例中对类型没有任何初始提示。
-- 因此,分析器查找所有候选操作符,发现既存在接受字符串类型范畴的操作符也存在接受位串类型范畴的操作符。
-- 因为字符串类型范畴是首选,所以选择字符串类型范畴的首选类型 text 作为解析未知类型文本的声明类型。
SELECT 'abc' || 'def' AS "unspecified";

-- 3.绝对值和取反操作符类型分析
-- 此处,系统在应用选定的操作符之前执行类一次 text 到 float8 的隐式转换。
SELECT @ '-4.5' AS "abs";
-- 我们可以验证它是 float8 而不是其它类型:
SELECT @ '-4.5e500' AS

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值