programing

다양한 경우에 테이블 열을 기준으로 정렬하려면 어떻게 해야 합니까(Oracle)

yellowcard 2023. 7. 4. 21:50
반응형

다양한 경우에 테이블 열을 기준으로 정렬하려면 어떻게 해야 합니까(Oracle)

다양한 대소문자(위쪽 및 아래쪽)가 있는 varchar2 열이 있는 테이블을 정렬하려면 어떻게 해야 합니까?

예를 들어 이름 열을 사용하여 주문하면 다음과 같은 결과가 나타납니다.

ANNIE
BOB
Daniel
annie
bob

제가 원하는 것은 다음과 같습니다.

ANNIE
annie
BOB
bob
Daniel

사용하다lower(field),예.

select * from tbl order by lower(name)

영어 이외의 언어에 대한 특수 문자를 지정해야 하는 경우 NLSSORT에 대한 다른 답변이 필요할 수 있습니다.만약 당신이 그렇게 하지 않는다면, 저는 키스하고 사용할 것입니다.lower()매우 쉽게 기억하고 사용하며 다른 사람에게 읽히기 때문에(가용성).

또 다른 옵션은 NLSSORT 함수를 사용하여 언어 정렬을 수행하는 것입니다.

SQL> with test as (select 'ANNIE' as col from dual
  2      union all select 'BOB' from dual
  3      union all select 'Daniel' from dual
  4      union all select 'annie' from dual
  5      union all select 'bob' from dual
  6      union all select 'Ångström' from dual
  7      union all select 'ångström' from dual)
  8  select col
  9  from test
 10  order by nlssort(col, 'NLS_SORT = WEST_EUROPEAN')
 11  /

COL
----------
Ångström
ångström
ANNIE
annie
BOB
bob
Daniel

장점은 유연성입니다.서로 다른 대소문자뿐만 아니라 억양이 있는 문자도 함께 정렬할 수 있습니다.NLS_SORT에 다른 값을 지정하여 일부 문자를 언어별로 처리하도록 선택할 수 있습니다.동등한 문자 집합 내에서 순서를 정의합니다.그래서 'A'와 'a'는 함께 분류되지만, 'a' 안에서는 대문자가 먼저 나옵니다.단점: 벤치마크를 하지 않았지만 NLSSORT가 LOWER보다 CPU를 더 많이 사용할 것으로 예상됩니다.그리고 NLSSORT는 더 긴 문자열의 접두사만 사용합니다.

반환된 문자열(수집 키라고도 함)은 RAW 데이터 유형입니다.지정된 조합의 문자 값으로 인해 발생하는 조합 키의 길이는 NLSSORT에서 반환하는 RAW 값의 최대 길이인 2000바이트를 초과할 수 있습니다.이 경우 NLSSORT는 계산된 결과가 2000바이트를 초과하지 않도록 문자의 최대 접두사 또는 초기 하위 문자열에 대한 정렬 키를 계산합니다.단일 언어 모음(예: 프랑스어)의 경우 접두사 길이는 일반적으로 1000자입니다.GENERIC_M과 같은 다국어 조합의 경우 접두사는 일반적으로 500자입니다.정확한 길이는 조합과 char에 포함된 문자에 따라 낮거나 높을 수 있습니다.

비교적 최근 버전의 Oracle을 사용하는 경우 LOWER() 함수를 사용하는 대신 NLS_SORT/NLS_COMP를 설정해야 합니다.

인스턴스에 전체적으로 영향을 미치지 않으려면 NLSORT() 함수를 사용하여 특정 쿼리 범위에 대한 NLS_SORT를 설정할 수 있습니다.

SQL> create table case_insensitive(a varchar2(10));

Table created.

SQL> insert into case_insensitive values('D');

1 row created.

SQL> 
SQL> 
SQL> c/'D/'c
  1* insert into case_insensitive values('c')
SQL> /

1 row created.

SQL> c/'c/'B
  1* insert into case_insensitive values('B')
SQL> /

1 row created.

SQL> c/'B/'a
  1* insert into case_insensitive values('a')
SQL> /

1 row created.

SQL> commit;

Commit complete.

SQL> select * from case_insensitive;

A
----------
D
c
B
a

SQL> select * from case_insensitive order by a;

A
----------
B
D
a
c

SQL> select * from case_insensitive order by nlssort(a,'NLS_SORT=BINARY_CI'); 

A
----------
a
B
c
D

여기에서 이에 대한 좋은 예를 찾을 수 있습니다.

사용할 수 있습니다.INITCAP

SELECT fld FROM tbl ORDER BY INITCAP(fld) ASC;

이에 대해 절별 주문을 사용할 수 있습니다.

select col_name from table_name 
order by col_name ;

언급URL : https://stackoverflow.com/questions/9788838/how-can-i-sort-by-a-table-column-in-varying-cases-oracle

반응형