홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
아리랑가요(무료음악채널)
뽕짝아가씨(무료음악채널)
okTrot(무료음악채널)
전통가요(무료음악채널)
미스트롯(무료음악채널)

온라이브스토어(앱다운로드)

환상의뽕짝파티 무료음악
명작트로트메들리 무료음악
트로트메들리관광 무료음악
동영상노래방
가사검색

POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
특정한 달의 생일인 사람 리스트 가져오기
7년 전
특정월에 대한 생일인 사람들의 리스트를 뽑는 쿼리문입니다.


단순히 양력만 사용한다면 아주 쉽게 할 수 있고,
음력포함하더라도 오늘 날짜 (특정일) 의 생일 목록도 쉽게 나오는데..
음력이 포함된 특정 달.. 이거 생각보다 상당히 복잡해지네요..
일단 음력 생일 데이타가 거의 없어 제대로 테스트는 안 되었습니다.
대충 해보니 잘 나오는거 같습니다.
비용은 크게 마니 안 드는거 같은데... 일단 쿼리문에서 반복이 좀 많은데...
이걸 어캐 좀 간단하게 처리할 방법은 없을까요? 반복구문을 함수로 만들긴 좀.... 뷰도 곤란하고..
의견있으신분 댓글 달아주세요..

PostgreSQL 용입니다만.. 쿼리문이 특별한 부분이 없으므로 타 DBMS 에서도 아주 조금만 고치면 얼마던지 적용 가능할 거 같습니다.
(이하 존칭 생략)


member - 회원테이블중 일부
user_id      text    : 사용자 아이디
birth_year  smallint : 생년월일 중 년도
birth_md    char(4)  : 생년월일 중 월일
solar          boolean  : 양/음 구분 (양력 true)

lunar - 양/음력 변환 테이블 중 일부
lumar_md char(4)  : 음력 년월일 중 월일
solars      integer  : 음력에 해당하는 양력을 년월일로 붙여 만든 숫자형
                            date 형의 컬럼도 있지만.. to_char 등의 함수를 쓰야 하기 때문에..
yun        boolean  : 윤달 여부 (윤달 true)

select lunar_y, lunar_md, solar, yun, solars from lunar;
-------+---------+------------+-------+-----------
lunar_y  lunar_md    solar      yun    solars
-------+---------+------------+-------+-----------
  1899 |    1201 | 1900-01-01 | f    | 19000101
  1899 |    1202 | 1900-01-02 | f    | 19000102
  1899 |    1203 | 1900-01-03 | f    | 19000103
  1899 |    1204 | 1900-01-04 | f    | 19000104
  ...........


<참고>
  1. PostgreSQL 에서는 날짜형이 엄격하기 때문에 음력을 제대로 표현할 수 없다.
      이럴테면 1990-02-30 과 같은 경우이다.
      그래서 음력 표현 방법중 년도와 월일을 분리하고 년도는 숫자 월일은 문자로 했다.
  2. 양/음력을 프로그램으로 변환할 수도 있지만 완벽하지 않으므로
      돌아다니는 1900 ~ 2200 까지의 음력 데이타 를 이용하였다.
  3. 윤달을 전혀 고려하지 않았다. 만일 윤달이라면 yun 을 true 로 하면 된다.
  4. 생일에 대한 년도는 필요없으나, 특정월에 대한 년도는 필요하다. (년마다 음력 날짜가 틀리므로)


먼저 특정 년월에 대한 마지막날을 구하는 함수를 만든다.
물론 만들 필요없이 바로 해당 위치에 집어 넣어도 아무런 상관은 없지만,
마지막일을 구하는 일은 종종 발생할 수 있기 때문에 미리 함수로 만들어놓으면 편하다.

create or replace function last_date (integer) returns date as
$$
  select (to_date($1, 'YYYYMM') + interval '1 month' - interval '1 day')::date;
$$ language sql;


select last_date(200702);                                            
last_date  
------------
2007-02-28

이런식으로 나옵니다.


prepare get_birthday (integer) as
(
  select * from member
  where (birth_md between
                                to_char(last_date($1), 'MM01')
                          and to_char(last_date($1), 'MMDD')
            and solar = true
            )
    or case when
            (select lunar_md from lunar
            where solars = ($1 || '01')::int
                and yun = false
            )
              >
            (select lunar_md from lunar
            where solars = to_char(last_date($1), 'YYYYMMDD')::int
                and yun = false
            )
        then (
                  (birth_md between
                                      (select lunar_md from lunar
                                      where solars = ($1 || '01')::int
                                          and yun = false
                                      )
                                and '1231'
                  )
                  or
                  (birth_md between
                                      '0101'
                                and (select lunar_md from lunar
                                      where solars = to_char(last_date($1), 'YYYYMMDD')::int
                                          and yun = false
                                      )
                  )
                  and solar = false
                )
        else
                (birth_md between
                                    (select lunar_md from lunar
                                    where solars = ($1 || '01')::int
                                        and yun = false
                                    )
                              and (select lunar_md from lunar
                                    where solars = to_char(last_date($1), 'YYYYMMDD')::int
                                        and yun = false
                                    )
                and solar = false
                )
        end
  order by user_id
);




샤용법은
execute get_birthday(200706);

prepare 로 지정하지 않고
저것 자체를 function 으로 만들고 함수 인자를 interger 로 받아 써도 좋겠죠?
추천추천 : 503 추천 목록
번호 제목
3,016
 우클릭 완벽차단 스크립트
3,015
 iframe 높이 100% 맞추기
3,014
 curl 함수를 이용한 HTTP REFERER 변경
3,013
 윈도우10 시스템 파일 및 Dism 검사
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
목록
추억의가요방(가사포함)
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
세월따라노래따라
가슴시린트로트
트로트쌍쌍파티
7080추억속으로
종합성인가요방
못잊을옛날노래
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

최신인기가요특집
추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.