如何用HSTORE函数在PostgreSQL中将行记录转换成键值对格式?

2026-04-27 18:391阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计807个文字,预计阅读时间需要4分钟。

如何用HSTORE函数在PostgreSQL中将行记录转换成键值对格式?

许多人在尝试使用 `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函数在PostgreSQL中将行记录转换成键值对格式?

许多人在尝试使用 `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",丢失大小写信息。

阅读全文
标签:键值对