Skip to Content
Go Back
안형우

안녕하세요. 14년차 풀스택 웹개발자 안형우입니다. 이 블로그에서는 WordPress, PHP, CSS, 사용성, 리눅스 서버 등 풀스택 웹개발에서 마주하는 다양한 문제 상황과 해결책, 필요한 개념들을 다룹니다. 👉 소개


작업물

📌 CSS가 어려운 이유 — 프로젝트 중심 실전 CSS 강의 소개 2023-04-13
📌 워드프레스, 답답한 빌더와 플러그인 대신 시원하게 커스터마징하기(강의) 2023-01-15
📌 아무도 말하지 않는 PHP의 좋은 점 2018-10-13
📌 유지보수하기 쉬운 CSS 전략(슬라이드) 2016-12-20
📌 워드프레스 테마에서 템플릿 파일 매칭 순서 2013-05-12
📌 [번역] CSS 코드 냄새 2013-01-01

[MySql] Select문 안에서 IF문 사용하기

추천글을 게시하는데, 시작일과 만료일을 기준으로 게시 여부를 판단하는 로직을 짜고 있었다.

관리자 페이지에서는 한 번에 이 목록을 불러 오되, 사용중인 글과 사용중이지 않은 글을 구분해서 보여 줘야 한다.

사용중인 글들을 위쪽에 표시하고, 그렇지 않은 놈들을 아래쪽에 몰아서 표시해 준다.

당연히 페이징 처리를 해야 한다.

으 썅 어떻게 하지? 처음에는 사용 여부를 DB에 저장해야 하나 하고 생각했다.

그러면 시작일과 만료일, 그리고 use_YN 이라는 이름의 컬럼을 만들어야 했다.

하지만 이것은 데이터 중복이다. 시작일과 만료일을 기준으로 사용여부를 가려낼 수 있는데 굳이 왜 또 사용여부라는 컬럼을 만들어야 하는가?

그러던 중 문득 mysql에서 함수를 사용하면 어떨까 하는 생각이 들었다.

즉, 함수를 이용해 use_YN이라는 가라 컬럼을 생성하면 어떨까 하는 생각이 들었던 것이다.

MySQL 에서 IF문 사용하기 라는 글이 도움을 줬다. 세 가지 용례를 정리해 둔 게 도움이 됐다.

그리고 그 결과 만든 쿼리다.

SELECT *, IF(`start_datetime` <= CURDATE() and `end_datetime` >= CURDATE(), 'Y', 'N') use_YN FROM `my_table`

위 쿼리를 사용하면 시작일과 만료일을 기준으로 현재 사용중인 글에는 Y가, 그렇지 않은 경우에는 N이 찍혀서 콘텐트가 들어온다. 컬럼명은 use_YN이다.

안녕하세요. 14년차 풀스택 웹개발자 안형우입니다. 이 블로그에서는 WordPress, PHP, CSS, 사용성, 리눅스 서버 등 풀스택 웹개발에서 마주하는 다양한 문제 상황과 해결책, 필요한 개념들을 다룹니다. 👉 소개


작업물

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다