> 데이터 베이스 > MySQL 튜토리얼 > MySQL은 쉼표로 구분된 문자열을 임시 테이블로 분할할 수 있습니까?

MySQL은 쉼표로 구분된 문자열을 임시 테이블로 분할할 수 있습니까?

DDD
풀어 주다: 2024-12-08 19:12:16
원래의
1025명이 탐색했습니다.

Can MySQL Split Comma-Separated Strings into a Temporary Table?

MySQL이 쉼표로 구분된 문자열을 임시 테이블로 분할할 수 있습니까?

쉼표로 구분된 문자열을 임시 테이블로 분할하는 것은 데이터 조작에서 일반적인 작업입니다. . MySQL에는 이 작업을 위한 내장 기능이 없지만 대체 방법을 사용하여 수행할 수 있습니다.

한 가지 접근 방식은 문자열 분할을 구현하는 사용자 정의 함수를 생성하는 것입니다. 제공된 답변의 SPLIT_STR 함수를 이 목적으로 사용할 수 있습니다. 구분 기호와 위치를 기준으로 하위 문자열을 반복적으로 추출하고, 일치하는 항목이 없으면 빈 문자열을 반환합니다.

분할 문자열을 반복하고 임시 테이블을 채우려면 루프를 사용할 수 있습니다. FOR 루프를 사용하여 SPLIT_STR 함수를 점진적으로 호출할 수 있으며 INSERT 쿼리를 사용하여 결과를 임시 테이블에 삽입할 수 있습니다.

그러나 이 접근 방식에는 사용자 정의 코딩과 MySQL 루프에 대한 지식이 필요하다는 점에 유의하는 것이 중요합니다. 통사론. 대체 솔루션은 PHP 또는 Python과 같은 스크립팅 언어를 사용하여 문자열 분할을 수행하고 결과를 임시 테이블에 삽입하는 것입니다.

다음은 분할 문자열을 반복하고 삽입하는 MySQL 루프에 대한 코드입니다. 값을 임시 테이블에 추가:

DELIMITER $$

CREATE PROCEDURE ABC(fullstr)

BEGIN
   DECLARE a INT Default 0 ;
   DECLARE str VARCHAR(255);
   simple_loop: LOOP
      SET a=a+1;
      SET str=SPLIT_STR(fullstr,"|",a);
      IF str='' THEN
         LEAVE simple_loop;
      END IF;
      #Do Inserts into temp table here with str going into the row
      insert into my_temp_table values (str);
   END LOOP simple_loop;
END $$
로그인 후 복사

위 내용은 MySQL은 쉼표로 구분된 문자열을 임시 테이블로 분할할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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