将 PostgreSQL 的 JSONB 转换为 Float
尝试对包含数值的 PostgreSQL JSONB 类型列执行算术运算时,可能会遇到错误,因为键入不匹配的内容。本文演示了如何克服此问题并成功将 JSONB 值转换为浮点数。
所提供查询中错误的根本原因是尝试将数值 (1.0) 添加到 JSONB 值,这会导致出现“运算符不存在”错误。为了解决这个问题,您可以在执行操作之前使用强制转换将 JSONB 值转换为浮点型。
但是,仅将 JSONB 值强制转换为浮点型可能还不够,因为 PostgreSQL 提供了两种访问 JSON 值的选项:
在您的具体情况下,因为你知道纬度值都是 JSON 数字,你可以使用以下查询将它们转换为浮点数:
SELECT (json_data->>'position'->>'lat')::float + 1.0 AS lat FROM updates LIMIT 5;
这个修改后的查询应该成功将 JSONB lat 值转换为浮点数,使您能够执行所需的操作。
以上是如何将 PostgreSQL JSONB 转换为浮点数以进行算术运算?的详细内容。更多信息请关注PHP中文网其他相关文章!