如何用HSTORE函数在PostgreSQL中将行记录转换成键值对格式?
- 内容介绍
- 文章标签
- 相关推荐
本文共计807个文字,预计阅读时间需要4分钟。
许多人在尝试使用 `hstore(my_table.*)` 或 `hstore(ROW(col1, col2))` 时遇到错误:
正确做法是显式展开字段,并确保键名和值一一对应:
SELECT hstore(ARRAY['id', 'name', 'active'], ARRAY[ id::text, name, active::text ]) FROM users LIMIT 1;
注意类型对齐:所有值必须是 text,布尔、数字、时间等需显式转成字符串,否则会报 array must have even number of elements 或类型不匹配错误。
用 json_to_hstore() 替代手动拼接,但仅限 PostgreSQL 14+
如果你用的是 PostgreSQL 14 或更新版本,json_to_hstore() 是更安全的选择,它能自动处理 NULL、布尔、数字等类型转换:
SELECT json_to_hstore(row_to_json(t)::jsonb) FROM (SELECT 1 AS id, 'Alice' AS name, true AS active) t;
但要注意:row_to_json() 生成的 JSON 键名全为小写,且无法控制字段顺序;如果原表有大小写混合列名(如 "UserId"),会被转成 "userid",丢失大小写信息。
本文共计807个文字,预计阅读时间需要4分钟。
许多人在尝试使用 `hstore(my_table.*)` 或 `hstore(ROW(col1, col2))` 时遇到错误:
正确做法是显式展开字段,并确保键名和值一一对应:
SELECT hstore(ARRAY['id', 'name', 'active'], ARRAY[ id::text, name, active::text ]) FROM users LIMIT 1;
注意类型对齐:所有值必须是 text,布尔、数字、时间等需显式转成字符串,否则会报 array must have even number of elements 或类型不匹配错误。
用 json_to_hstore() 替代手动拼接,但仅限 PostgreSQL 14+
如果你用的是 PostgreSQL 14 或更新版本,json_to_hstore() 是更安全的选择,它能自动处理 NULL、布尔、数字等类型转换:
SELECT json_to_hstore(row_to_json(t)::jsonb) FROM (SELECT 1 AS id, 'Alice' AS name, true AS active) t;
但要注意:row_to_json() 生成的 JSON 键名全为小写,且无法控制字段顺序;如果原表有大小写混合列名(如 "UserId"),会被转成 "userid",丢失大小写信息。

