> 데이터 베이스 > MySQL 튜토리얼 > MySQL 텍스트 필드에서 연속 숫자를 어떻게 추출할 수 있습니까?

MySQL 텍스트 필드에서 연속 숫자를 어떻게 추출할 수 있습니까?

Linda Hamilton
풀어 주다: 2024-11-30 15:15:13
원래의
341명이 탐색했습니다.

How Can I Extract Consecutive Digits from MySQL Text Fields?

MySQL 텍스트 필드에서 연속 숫자 추출

MySQL의 텍스트 필드에서 연속 숫자를 효과적으로 추출하려면 다음과 같은 몇 가지 접근 방식이 있습니다.

일반 사용 표현식:

MySQL에 내장된 정규 표현식 지원을 활용하면 텍스트 필드 내에서 두 개의 연속 숫자가 나타나는 것을 감지할 수 있습니다. 그러나 이 방법은 숫자를 별도의 필드로 추출하지 않습니다.

PCRE를 사용한 사용자 정의 함수:

고급 정규식 기능을 사용하려면 LIB_MYSQLUDF_PREG 구현을 고려하세요. 이 오픈 소스 라이브러리는 문자열에서 특정 일치 항목을 추출할 수 있는 PREG_CAPTURE, PREG_POSITION, PREG_REPLACE 및 PREG_RLIKE와 같은 함수를 제공합니다.

사용자 정의 함수:

대체 접근 방식 REGEXP_EXTRACT와 같은 사용자 정의 함수를 생성하여 원하는 정규식 패턴과 일치하는 가장 긴 하위 문자열을 추출하는 것입니다. 이 기능을 사용하면 추가 문자를 포함하지 않고 숫자를 캡처하기 위해 시작 및 끝 위치 조정을 지정할 수 있습니다.

추가 기준:

추출된 숫자를 20보다 큰 특정 값의 경우 숫자를 가져온 후 MySQL 쿼리에 추가 기준을 적용할 수 있습니다. field.

예:

다음 사용자 지정 함수 구현을 고려하세요.

CREATE FUNCTION REGEXP_EXTRACT(string TEXT, exp TEXT)
RETURNS TEXT
DETERMINISTIC
BEGIN
  ...
  ...
END
로그인 후 복사

그런 다음 쿼리에서 이 함수를 사용하여 두 가지를 추출할 수 있습니다. 원본 텍스트 필드의 연속된 숫자를 값으로 필터링합니다.

SELECT `id`, REGEXP_EXTRACT(`originaltext`, '[0-9][0-9]') AS `digits`
FROM `source`
WHERE `digits` > 20;
로그인 후 복사

위 내용은 MySQL 텍스트 필드에서 연속 숫자를 어떻게 추출할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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