"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > SQL에서 쉼표로 구분 된 목록에서 n 값을 안정적으로 추출하여 NULLS를 처리하는 방법은 무엇입니까?

SQL에서 쉼표로 구분 된 목록에서 n 값을 안정적으로 추출하여 NULLS를 처리하는 방법은 무엇입니까?

2025-02-12에 게시되었습니다
검색:710

How to Reliably Extract the Nth Value from a Comma-Separated List in SQL, Handling Nulls?

regexp_substrs를 사용하여 쉼표로 분리 된 목록에서 nth 값을 추출 할 때 nulls

가있는 쉼표로 구분 된 목록에서 특정 값을 선택하기위한 REGEX 솔루션 (), 널 값을 처리하는 것은 까다로울 수 있습니다. 다음은 문제와 포괄적 인 솔루션에 대한 자세한 검사입니다.

먼저 다음 시나리오를 고려하십시오. '[^,]', 1, 2) 데이터 이중에서; 디 - 2
SQL> select REGEXP_SUBSTR('1,2,3,4,5,6', '[^,] ', 1, 2) data
from dual;

D
-
2
이 쿼리는 정규 표현식 [^,]을 사용하여 목록에서 두 번째 비 널 값 ( "2")을 성공적으로 검색합니다. 그러나 두 번째 값이 null이면 쿼리는 세 번째 항목을 반환합니다.

sql> regexp_substr ( '1 ,, 3,4,5,6', '[^,]', 1, 2 ) 데이터 이중에서; 디 - 3
SQL> select REGEXP_SUBSTR('1,2,3,4,5,6', '[^,] ', 1, 2) data
from dual;

D
-
2
이 문제를 해결하려면 선택적인 문자를 허용하기 위해보다 유연한 정규식이 필요합니다. ^,]*', 1, 4) 데이터 이중에서; 디 - 3

그러나이 regex는 널을지나 숫자에 대해서도 실패합니다.
SQL> select REGEXP_SUBSTR('1,2,3,4,5,6', '[^,] ', 1, 2) data
from dual;

D
-
2
궁극적으로 솔루션은보다 정교한 Regex :

regex_substr ( '1 ,, 3, 4,5 ','(.*?) (, | $) ', 1, 2, null, 1)

이것은 쉼표 또는 줄의 끝이 발생하기 전에 데이터를 캡처합니다. . 결과는
SQL> select REGEXP_SUBSTR('1,2,3,4,5,6', '[^,] ', 1, 2) data
from dual;

D
-
2
데이터입니다 ----

이 솔루션을 재사용 가능한 함수로 캡슐화하려면 다음 코드를 고려하십시오. 시작하다 return regexp_substr (string_in, '(.*?) (\'|| delimiter_in || '| $)', 1, element_in, null, 1); end get_list_element;
SQL> select REGEXP_SUBSTR('1,2,3,4,5,6', '[^,] ', 1, 2) data
from dual;

D
-
2
이 함수는 다음과 같이 호출 될 수 있습니다 :

듀얼에서 get_list_element ( '123,222 ,, 432,555', 4)를 선택하십시오.
SQL> select REGEXP_SUBSTR('1,2,3,4,5,6', '[^,] ', 1, 2) data
from dual;

D
-
2

특정 요소를 선택하고있는이 솔루션은 Oracle SQL에서 쉼표로 구분 된 목록에서 값을 추출하는 강력하고 우아한 방법을 제공합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3