> 데이터 베이스 > MySQL 튜토리얼 > CTE를 사용하여 SQLite에서 쉼표로 구분된 값을 효율적으로 분할하려면 어떻게 해야 합니까?

CTE를 사용하여 SQLite에서 쉼표로 구분된 값을 효율적으로 분할하려면 어떻게 해야 합니까?

Mary-Kate Olsen
풀어 주다: 2025-01-04 03:12:11
원래의
154명이 탐색했습니다.

How Can I Efficiently Split Comma-Separated Values in SQLite Using CTEs?

SQLite에서 쉼표로 구분된 값 분할

SQLite에서 쉼표로 구분된 문자열을 사용하는 또 다른 접근 방식은 공통 테이블 표현식(CTE)을 활용하는 것입니다. ). CTE는 문자열을 개별 값으로 효과적으로 분할하는 수단을 제공합니다.

단계별 구현:

  1. CTE 만들기: 두 개의 매개변수(개별 값을 보유하는 단어와 쉼표로 구분된 값을 저장하는 csv)를 허용하는 분할이라는 CTE를 정의하는 것으로 시작합니다. string.
  2. 초기 쿼리: CTE의 초기 쿼리에서는 끝을 표시하기 위해 추가 쉼표를 연결하여 CSV 문자열을 지정합니다.
  3. 재귀 쿼리: 재귀 쿼리는 substr() 및 instr()을 사용하여 다음 단어까지 첫 번째 단어를 추출합니다. 쉼표를 입력하고 csv를 업데이트하여 구문 분석된 부분을 제거하세요. 이 프로세스는 더 이상 쉼표가 발견되지 않을 때까지 반복됩니다.
  4. 결과 선택: 마지막으로 원시 CSV 문자열을 나타내는 첫 번째 및 마지막 행을 제외하고 CTE에서 단어 열을 선택합니다. 잔여 비어 있음 text.

예:

다음은 CTE 접근 방식을 설명하는 코드 샘플입니다.

WITH split(word, csv) AS (
  SELECT '', 'Auto,A,1234444'||','
  UNION ALL SELECT
    substr(csv, 0, instr(csv, ',')),
    substr(csv, instr(csv, ',') + 1)
  FROM split
  WHERE csv != ''
) SELECT word FROM split 
WHERE word!='';
로그인 후 복사

출력:

Auto
A
1234444
로그인 후 복사

이 방법은 간결하고 효율적인 분할 방법을 제공합니다. SQLite에서 쉼표로 구분된 문자열을 사용하여 개별 값에 쉽게 액세스할 수 있습니다.

위 내용은 CTE를 사용하여 SQLite에서 쉼표로 구분된 값을 효율적으로 분할하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿