sql 질문입니다..
본문
SELECT wr_2, wr_3, count(*) AS loginCount FROM 테이블GROUP BY wr_3 HAVING count(*) > 1 order by loginCount desc
이 명령어를 통해 wr_3이 중복되는 숫자를 추출했습니다.
근데 양이 워낙 많다보니
높은 숫자순으로 상위 10개만 보여주고 싶은데
select top(n)
이렇게 시작하라는 내용을 찾아서 적용을 했는데 되직가 않네용,,
혹시 방법이 있을까요?
추가로
where절을 추가해서 특정 날짜부터 보고싶어서
SELECT wr_2, wr_3, count(*) AS loginCount FROM 테이블 GROUP BY wr_3 HAVING count(*) > 1 where wr_datetime between '2018-01-02' and '2018-01-09' order by loginCount desc
아무것도 뜨지가 않네요,,
도움 부탁드립니다..
!-->!-->답변 2
쿼리문 뒤에 limit 를 주세요
order by loginCount desc
limit 10;
두번째 기간을 주려면
비교하려는 문장과 조건의 구조가 동일해야 하는데
datetime 과 date형과 비교하였기에 나오질 않는겁니다.
where 절을
where date_format(wr_datetime, '%Y-%m-%d') between '2018-01-02' and '2018-01-09'
이렇게 변경하시면 정상적으로 나올겁니다.
!-->
답변을 작성하시기 전에 로그인 해주세요.