-- 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
5.pgsql类型转换
最新推荐文章于 2025-03-12 13:57:30 发布