[MySQL] Like in 같이 쓰기, REGEXP > db

본문 바로가기

db

[MySQL] Like in 같이 쓰기, REGEXP

페이지 정보

작성자 서방님 댓글 0건 조회 17회 작성일 19-08-23 10:38

본문



Mysql과 MariaDB에서 like와 in을 동시에 사용한 것과 동일한 결과를 출력하는 방법


다른 DBMS는 모르겠지만 mysql에서는 like와 in을 함께 사용 할 수가 없다. 물론 마리아DB도 마찬가지로 사용을 할 수 없다.


그러나 개발을 하다보면 like와 in을 동시에 사용할 수 있으면 좋겠다는 생각을 하게 되는데


그에 대한 해결책이다.


방법을 몰라 애멀게 구글에서 like in만 주구장창 검색을 하다가 겨우 찾아낸 방법이다


그리고 이렇게나 간단한 방법이 있는데도 내가 몰라서 개고생 한걸 생각하면 역시 머리가 나쁘면


손발이 고생한다는 말을 되뇌이게 된다.


매우 간단한 방법이다.


Select SEARCH_TEXT
From SEARCH_TBL
Where SEARCH_TEXT REGEXP  '헤이|모두들|안녕|내가|누군지|아니'



위와 같이 조건을 주게 되면 REGEXP라는 정규식을 사용하면


like 와 in을 동시에 사용한것과 같이 데이터 베이스의 search_tbl이라는 테이블 안에 있는  SEARCH_TEXT라는 컬럼 로우에


헤이, 모두들, 안녕, 내가, 누군지, 아니 이 6개 단어중에 하나라도 포함이 된 로우는


전부 출력을 해주게 된다.


지저분하게 검색조건에 like를 몇개씩 늘이지 않아도 된다.


저걸 like만으로 사용하게 된다면


Select SEARCH_TEXT
From SEARCH_TBL
Where SEARCH_TEXT like '%헤이%'
	Or SEARCH_TEXT like '%모두들%'
	Or SEARCH_TEXT like '%안녕%'
	Or SEARCH_TEXT like '%내가%'
	Or SEARCH_TEXT like '%누군지%'
	Or SEARCH_TEXT like '%아니%'


이런 장황한 쿼리가 되어 버린다.



REGEXP를 사용하는 정규식에 대해선 아직 잘 모르지만 급하게 like와 in을 동시에 사용 하는 방법과


비슷한 결과를 원한다면 몰라도 원하는 값만 출력해준다면 가져다 쓰면 유용할 듯 하다.


여기에 조금더 응용을 하게 되면 REGEXP 다음에 나오는 정규식을 서브쿼리를 이용해 만들 수도 있다


예를 들어 아래와 같은 쿼리를 구현할 수가 있다.


Select SEARCH_TEXT
From SEARCH_TBL
Where SEARCH_TEXT REGEXP (
	Select REPLACE(GROUP_CONCAT(TAG_NAME),',','|') As NAME
	From (
		Select Distinct TAGLIST.TAG_NAME, TAGLIST.ROOT_TAG
		From ITEM_LIST LIST
		Inner Join ITEM_LIST TARGET On TARGET.ROOT_TAG = LIST.ROOT_TAG
		Where TARGET.TAG_NAME like '조건1'
			Or TARGET.TAG_NAME like '조건2'
	) SelectTagList
)


문자열을 바꿔주는 REPLACE와 값을 이어주는 GRUOP_CONCAT 함수를 사용하며


서브쿼리로 정규식의 모양새를 만들어주고 그 결과로 조건을 만드는 방법이다.


REPLACE와 CONCAT함수는 sql 쿼리 작성시에 유용하게 자주 사용되니 알아두자.


댓글목록

등록된 댓글이 없습니다.

Total 456건 1 페이지
게시물 검색

회원로그인

접속자집계

오늘
54
어제
413
최대
592
전체
83,811

그누보드5
Copyright © 서방님.kr All rights reserved.