PostgreSQL では、JSONB データを使用して数学演算を実行しようとすると、への変換時に「演算子が存在しません」などのエラーが発生することがよくあります。 float は明示的に指定されていません。
この問題を解決するには、別の JSON 値の取得を検討してください。演算子:
float は JSONB のテキストとして保存されるため、 ->> を使用する必要があります。 (二重矢印) 演算子を使用して、float にキャストする前に float の文字列表現を抽出します。
たとえば、次のクエリを考えてみましょう。
SELECT (json_data->'position'->'lat')::float + 1.0 AS lat FROM updates LIMIT 5
ここで、-> (矢印) 演算子は、最初は JSON オブジェクト「位置」を抽出するために使用されます。 ->>次に、(二重矢印) 演算子を使用して、「lat」の文字列値を取得します。最後に、::float キャスト演算子を使用して文字列を float に変換します。
適切な JSON 値取得演算子を利用することで、PostgreSQL クエリで JSONB 値を float に正常にキャストできます。
以上が数学的演算のために PostgreSQL JSONB データを Float にキャストする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。