postgresql 18版bytea 类型转换的改进

文档看到如下例子

复制代码
此外,还可以将整数值转换为 bytea 类型,反之亦然。将整数转换为 bytea 会根据整数类型的宽度生成 2、4 或 8 个字节。结果是整数的二补数表示,最高有效字节在前。一些示例:

1234::smallint::bytea          \x04d2
cast(1234 as bytea)            \x000004d2
cast(-1234 as bytea)           \xfffffb2e
'\x8000'::bytea::smallint      -32768
'\x8000'::bytea::integer       32768

测试了一下,确实如此

复制代码
psql (18.0 (Debian 18.0-1.pgdg13+3))
Type "help" for help.

postgres=# select 1234::bytea;
   bytea
------------
 \x000004d2
(1 row)

postgres=# select 1234::smallint::bytea;
 bytea
--------
 \x04d2
(1 row)

作为比较,17.7版不支持以上操作, 只支持把字符串转换为bytea 类型

复制代码
postgres=# select 1234::smallint::bytea;
ERROR:  cannot cast type smallint to bytea
LINE 1: select 1234::smallint::bytea;
                             ^
postgres=# select 1234::bytea;
ERROR:  cannot cast type integer to bytea
LINE 1: select 1234::bytea;
                   ^
postgres=# select '1234'::bytea;
   bytea
------------
 \x31323334
(1 row)

postgres=# select 1234::smallint::text::bytea;
   bytea
------------
 \x31323334
(1 row)
相关推荐
XDHCOM18 小时前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜19 小时前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage19 小时前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
liliangcsdn19 小时前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜19 小时前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick199319 小时前
SQL 执行流程
数据库·sql
M--Y19 小时前
Redis常用数据类型
数据结构·数据库·redis
猿小喵20 小时前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
Y0011123620 小时前
MySQL-进阶
开发语言·数据库·sql·mysql
徒 花20 小时前
数据库知识复习01
数据库