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