728x90
REGEXP 정규표현식 (Regular Expression)
- 문자열 처리하는 방법
- 특정한 조건의 문자를 검색하거나 치환할 때 사용
[Pattern기능예시설명]
Matching
. | 문자 하나 | "..." | 문자열의 길이가 세 글자 이상인 것을 찾음. |
I | 또는 (OR). I(수직선)로 구분된 문자에 해당하는 문자열을 찾음. | "데이터I데이타" | ‘데이터’ 또는 ‘데이타’에 해당하는 문자열을 찾음. |
[] | [] 안에 나열된 패턴에 해당하는 문자열을 찾음. | "[123]d" | 대상 문자열에서 ‘1d’ 또는 ‘2d’ 또는 ‘3d’인 문자열을 찾음. |
^ | 시작하는 문자열을 찾음. | "^안녕" | 대상 문자열에서 ‘안녕’으로 시작하는 문자열을 찾음. |
$ | 끝나는 문자열을 찾음. | "잘가$" | 대상 문자열에서 ‘잘가’로 끝나는 문자열을 찾음. |
Numbers Limit
* | 0회 이상 나타나는 문자 | "a*" | ‘a’가 0번 이상 등장하는 문자열을 찾음. ‘b’, ‘a’, ‘aa’ 모두 해당. |
+ | 1회 이상 나타나는 문자 | "국+" | ‘국’이 1번 이상 등장하는 문자열을 찾음. ‘한국’, ‘미역국’, ‘국거리’ 모두 해당. |
{m,n} | m회 이상 n회 이하 반복되는 문자 | "치{1,2}" | ‘치’가 1회 이상 2회 이하 반복하는 문자열을 찾음. ‘치커리’, ‘치카치카’ 모두 해당. |
? | 0~1회 나타나는 문자 | "[가나다]?" | ‘가’ 또는 ‘나’ 또는 ‘다’가 0~1회 등장하는 문자열을 찾음. ‘가지마’, ‘나라’, ‘안녕’ 모두 해당. |
String Group
[A-z] 또는 [:alpha:] 또는 \a | 알파벳 대문자 또는 소문자인 문자열을 찾음 | "[A-z]+" | 대상 문자열에서 알파벳이 한 개 이상인 문자열을 찾음 |
[0-9] 또는 [:digit:] 또는 \d | 숫자인 문자열을 찾음 | "^[0-9]+" | 한 개 이상의 숫자로 시작하는 문자열을 찾음 |
Not
[^문자] | 괄호 안의 문자를 포함하지 않은 문자열을 찾음 | "[^길로그]" | ‘길’ 또는 ‘로’ 또는 ‘그’를 포함하지 않는 문자열을 찾음. ‘길가’, ‘로그’, ‘그리고’ 모두 제외됨. |
EX) 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기
- '통풍시트', '열선시트', '가죽시트' 중 하나 이상의 옵션이 포함된 자동차가 자동차 종류 별로 몇 대인지 출력
SELECT CAR_TYPE, COUNT(*) CARS
FROM CAR_RENTAL_COMPANY_CAR
WHERE OPTIONS REGEXP '통풍시트|열선시트|가죽시트'
GROUP BY CAR_TYPE
ORDER BY CAR_TYPE
728x90
'𝙎𝙌𝙇' 카테고리의 다른 글
[MySQL] NULL값 제외 COUNT : IS NOT NULL (0) | 2023.01.15 |
---|---|
[MySQL] 반올림 : ROUND() / 버림 : TRUNCATE() (0) | 2023.01.15 |
[MySQL] 두 테이블 합치기 : UNION / UNION ALL 차이 (0) | 2023.01.14 |
[MySQL] 날짜 차이 구하기 : DATEDIFF / TIMESTAMPDIFF (0) | 2023.01.13 |
[MySQL] 조건문 CASE~WHEN / IF~ELSE (0) | 2023.01.13 |