>데이터 베이스 >MySQL 튜토리얼 >Oracle SQL 쿼리에서 USD 통화의 우선 순위를 지정하는 방법은 무엇입니까?

Oracle SQL 쿼리에서 USD 통화의 우선 순위를 지정하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-23 19:29:17812검색

How to Prioritize USD Currency in Oracle SQL Queries?

Oracle SQL의 사용자 정의 순서: 통화 우선순위

다양한 통화로 거래가 포함된 데이터를 쿼리할 때 결과를 기준으로 정렬해야 하는 경우가 많습니다. 사용자 정의 환경 설정에. 이 특정 시나리오에서는 USD 통화를 순서의 맨 위에 배치하고 나머지 통화를 오름차순으로 정렬해야 합니다.

Oracle SQL은 이러한 사용자 정의 순서를 달성하기 위한 여러 가지 방법을 제공합니다. 한 가지 접근 방식은 각 통화에 숫자 값이나 문자열을 할당하는 CASE 표현식을 사용하는 것입니다.

order by 
    case 
       when currency = 'USD' then 1 
       when currency = 'BHT' then 2
       when currency = 'JPY' then 3
       when currency = 'MYR' then 4
       else 5
    end

또는 DECODE 함수를 사용하여 동일한 매핑을 수행할 수 있습니다.

order by decode(currency, 'USD', 1, 'BHT', 2, 'JPY', 3, 'MYR', 4, 5)

그러나 이 방법은 우선순위에 따라 통화를 명시적으로 지정해야 하기 때문에 통화 목록이 광범위하거나 다음과 같은 경우에는 번거로울 수 있습니다. 변경하세요.

데이터의 통화 수나 유형에 관계없이 일관된 순서를 보장하기 위한 또 다른 접근 방식은 통화를 문자 값으로 변환하고 알파벳 순서를 사용하는 것입니다.

order by 
    case 
       when currency = 'USD' then '001' 
       else currency
    end

문자는 숫자순으로 정렬되므로 이 방법을 사용하면 USD가 순서의 맨 위에 배치되고 나머지 통화는 알파벳순으로 정렬됩니다.

위 내용은 Oracle SQL 쿼리에서 USD 통화의 우선 순위를 지정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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