정규표현식은 특정 패턴을 가진 문자열을 검색하거나 추출, 교체할 때 사용하는 표현 방식입니다.
SQL에서는 주로 데이터를 검색하거나 필터링할 때 활용됩니다.
대표적으로 다음 함수가 사용됩니다.
REGEXP_LIKE, REGEXP_INSTR, REGEXP_SUBSTR, REGEXP_REPLACEREGEXP, RLIKE, REGEXP_LIKE~, ~*, !~, !~*, regexp_matches, regexp_replace, regexp_split_to_table| 데이터베이스 | 설명 및 예시 |
|---|---|
| Oracle | WHERE REGEXP_LIKE(column, '[A-Z]{3}[0-9]{3}') |
| MySQL | WHERE column REGEXP '^[A-Za-z]+[0-9]+$' |
| PostgreSQL | WHERE column ~* 'pattern' (대소문자 구분하지 않음) |
| 기호 | 설명 | 예시 | 매칭 결과 |
|---|---|---|---|
^ | 문자열의 시작 지점 | ^A | A로 시작하는 문자열만 매칭 |
$ | 문자열의 끝 지점 | Z$ | Z로 끝나는 문자열만 매칭 |
. | 모든 단일 문자 (개행 제외) | a.b | aab, acb, adb 등 |
* | 앞의 문자 0회 이상 반복 | ab*c | ac, abc, abbc 등 |
+ | 앞의 문자 1회 이상 반복 | ab+c | abc, abbc 등 |
? | 앞의 문자가 없거나 한 번만 존재 | colou?r | color, colour |
\ | 특수문자를 일반 문자로 변환 (escape) | \. | 문자.과 매칭 |
[ ] | 문자 집합 중 하나 | [abc] | a, b, 또는 c와 매칭 |
[^ ] | 문자 집합이 아닌 문자 | [^abc] | a, b, c 제외 모든 문자 |
[a-z] | 문자 범위 지정 | [0-9] | 숫자 한자리 |
{n} | 정확히 n회 반복 | [0-9]{3} | 숫자 3자리 |
{n,m} | 최소 n회, 최대 m회 반복 | [A-Z]{2,4} | 대문자 2~4개 |
( ) | 그룹 지정 | (abc)+ | abc, abcabc, 등 |
| ` | ` | OR 조건 | `dog |
SELECT emp_name
FROM employee
WHERE REGEXP_LIKE(emp_id, '^[A-Z]{2}[0-9]{4}$');
-- 예) emp_id가 AB1234 형태 SELECT name
FROM user
WHERE email REGEXP '^[a-zA-Z0-9._%-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$';
-- 예) 이메일 형태 검증 SELECT product_code
FROM product
WHERE product_code ~ '^PRD[0-9]{3}$';
-- 예) PRD로 시작하며 숫자 3자리로 끝나는 코드 ^[a-zA-Z0-9._%-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$ ^[0-9]{2,3}-[0-9]{3,4}-[0-9]{4}$ ^[0-9]{6}-[1-4][0-9]{6}$ ^[a-zA-Z]+[0-9]+$ ^[가-힣]+$ 이 자료를 참고하여 SQL에서 효과적인 데이터 필터링과 패턴 매칭 작업을 수행할 수 있습니다.
코스피 8% 폭락, 서킷브레이커 발동, SK텔레콤 Claude AI 차단까지. 한국의 AI 레버리지 버블이 단 하루…
SNS 사진 1장으로 30초 만에 딥페이크 영상이 완성됩니다. 당신의 얼굴이 이미 범죄에 악용되고 있을 수…
SNS 사진 1장으로 30초 만에 딥페이크 영상이 완성됩니다. 당신의 얼굴이 이미 범죄에 악용되고 있을 수…
달러/원 환율이 급등하는 이유와 실생활 영향을 정리했습니다. 지금 당장 활용할 수 있는 환전·투자 대응 전략까지…
미래에셋·미래에셋벤처투자·미래에셋생명이 동반 급등한 이유는 스페이스X 상장 기대감입니다. 세 회사가 스페이스X와 어떻게 연결되어 있는지 상세히 분석했습니다.
스페이스X 상장이 계속 미뤄지는 진짜 이유를 파헤쳤습니다. 화성 계획, 스타링크 분리, 국방 계약... 머스크가 절대…