>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL은 정수 나누기를 어떻게 처리하며 정확한 결과를 어떻게 얻을 수 있습니까?

PostgreSQL은 정수 나누기를 어떻게 처리하며 정확한 결과를 어떻게 얻을 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-26 18:40:18134검색

How Does PostgreSQL Handle Integer Division, and How Can I Get Accurate Results?

PostgreSQL의 나누기 연산자: 정수 잘림 및 부동 소수점 계산 이해

PostgreSQL에서 나누기 연산(/)은 예상치 못한 결과를 초래할 수 있습니다. 정수 값으로 작업할 때. 잘못된 계산을 방지하려면 정수 나누기의 기본 동작을 이해하는 것이 중요합니다.

다음 쿼리를 고려하세요.

SELECT dev_cost / sell_cost FROM software

여기서 dev_cost는 16000이고 Sell_cost는 7500입니다. 결과는 다음과 같습니다. 3이지만 2를 반환합니다. 이는 정수 나누기가 소수 부분을 자르기 때문입니다. result.

원하는 값을 얻으려면 값 중 하나 이상을 부동 소수점 유형(예: 십진수)으로 변환하거나 :: 연산자를 사용하여 즉시 변환해야 합니다.

SELECT CAST(dev_cost AS DECIMAL) / sell_cost FROM software
SELECT dev_cost::DECIMAL / sell_cost FROM software

이러한 쿼리는 실제 나누기 결과인 2.133을 반환합니다.

또한 다음을 사용할 수 있습니다. 결과를 가장 가까운 정수로 반올림하는 ceil() 함수:

SELECT CEIL(dev_cost::DECIMAL / sell_cost) FROM software

이 쿼리는 개발 비용을 회수하기 위해 원하는 소프트웨어 수량인 3을 반환합니다.

입니다. 나누기 작업을 수행할 때 이러한 동작을 인식하고 적절한 데이터 유형과 캐스팅을 사용하여 정확한 계산을 보장하는 것이 중요합니다.

위 내용은 PostgreSQL은 정수 나누기를 어떻게 처리하며 정확한 결과를 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.