> 데이터 베이스 > MySQL 튜토리얼 > 산술 연산을 위해 PostgreSQL JSONB를 부동 소수점으로 캐스팅하는 방법은 무엇입니까?

산술 연산을 위해 PostgreSQL JSONB를 부동 소수점으로 캐스팅하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-02 21:18:38
원래의
258명이 탐색했습니다.

How to Cast PostgreSQL JSONB to Float for Arithmetic Operations?

PostgreSQL의 JSONB를 Float로 캐스팅

숫자 값이 포함된 PostgreSQL JSONB 유형 열에서 산술 연산을 수행하려고 하면 다음과 같은 오류가 발생할 수 있습니다. 불일치를 입력합니다. 이 문서에서는 이 문제를 극복하고 JSONB 값을 부동 소수점으로 성공적으로 변환하는 방법을 보여줍니다.

제공된 쿼리에서 오류의 근본 원인은 JSONB 값에 숫자 값(1.0)을 추가하려는 시도로 인해 발생합니다. "연산자가 존재하지 않습니다" 오류가 발생합니다. 이 문제를 해결하려면 작업을 수행하기 전에 캐스팅을 사용하여 JSONB 값을 부동 소수점으로 변환할 수 있습니다.

그러나 PostgreSQL은 JSON 값에 액세스하기 위한 두 가지 옵션을 제공하므로 단순히 JSONB 값을 부동 소수점으로 캐스팅하는 것만으로는 충분하지 않을 수 있습니다.

  • json_data->'position': JSON 값을 반환합니다. 이 값은 직접 캐스팅할 수 없습니다. float.
  • json_data->>'position': ::float를 사용하여 부동 소수점으로 변환할 수 있는 텍스트 값을 반환합니다.

특정 경우에는 이후 위도 값이 모두 JSON 숫자라는 것을 알고 있으면 다음 쿼리를 사용하여 이를 부동 소수점으로 변환할 수 있습니다.

SELECT (json_data->>'position'->>'lat')::float + 1.0 AS lat
FROM updates
LIMIT 5;
로그인 후 복사

이 수정된 쿼리는 성공적으로 수행되어야 합니다. JSONB 위도 값을 부동 소수점으로 변환하여 원하는 작업을 수행할 수 있습니다.

위 내용은 산술 연산을 위해 PostgreSQL JSONB를 부동 소수점으로 캐스팅하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿