> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 정규식을 사용하여 문자열을 어떻게 바꿀 수 있습니까?

MySQL에서 정규식을 사용하여 문자열을 어떻게 바꿀 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-14 01:48:09
원래의
251명이 탐색했습니다.

How Can I Use Regular Expressions to Replace Strings in MySQL?

MySQL에서 정규식 대체 수행

MySQL에서는 문자열을 처리하고 복잡한 텍스트 조작을 수행하는 것이 필수적인 경우가 많습니다. 일반적인 작업 중 하나는 문자열 내의 특정 패턴을 바꾸는 것입니다. 특히 정규식을 사용하여 이를 수행합니다. 이 기사에서는 MySQL에서 정규식 대체를 수행하는 방법을 자세히 알아볼 것입니다.

REGEXP_REPLACE: 정규식 대체를 위한 MySQL 솔루션

최신 버전의 MySQL(8.0 이상) ), REGEXP_REPLACE라는 전용 함수가 도입되었습니다. 이 기능을 사용하면 정규식을 활용하여 직접 교체가 가능합니다. REGEXP_REPLACE 구문은 다음과 같습니다.

REGEXP_REPLACE(input_string, regexp, replace_string)
로그인 후 복사

여기서:

  • input_string은 대체를 위해 처리할 문자열입니다.
  • regexp는 정규식 패턴입니다. 일치 및 교체.
  • replace_string은 다음에서 지정한 일치 항목을 대체할 문자열입니다. regexp.

REGEXP_REPLACE 사용 예

filename이라는 열에 다양한 관련 없는 문자가 포함된 파일 이름이 포함된 시나리오를 생각해 보세요. 정규식을 사용하여 이러한 문자를 제거하려면 다음 쿼리를 사용할 수 있습니다.

SELECT REGEXP_REPLACE(filename, '[^a-zA-Z0-9()_ .-]', '')
FROM your_table;
로그인 후 복사

정규식 [^a-zA-Z0-9()_ .-]는 영숫자 문자, 괄호, 밑줄, 마침표 또는 하이픈. REGEXP_REPLACE의 빈 문자열은 일치하는 문자를 제거해야 함을 나타냅니다.

REGEXP_REPLACE의 그룹화

REGEXP_REPLACE 함수는 정규식 그룹화도 지원하므로 복잡한 대체가 가능합니다. 예를 들어, 다음 쿼리는 스택과 오버 부분을 하이픈으로 대체하여 "stackoverflow"라는 단어를 재정렬합니다.

SELECT REGEXP_REPLACE("stackoverflow", "(stack)(over)(flow)", "\2 - \1 - \3")
로그인 후 복사

이 쿼리의 결과는 "over - stack - flow"입니다.

위 내용은 MySQL에서 정규식을 사용하여 문자열을 어떻게 바꿀 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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