웹마스터 팁

xe_point 테이블을 이용하여 순위 뽑을 때 보통의 경우로 정렬하게 되면 포인트가 같은 경우 member_srl 등의 2차적 정렬사항으로
순위가 다르게 표시 됩니다.
본 소개는 이를 같은 순위로 표기하고 그 앞에 '공동'이란 특정 값을 표시하게 해주는 원리 입니다.

보시고 참고하실 분은 참고하시고요...

※ 이거 해서 된다는 건 아닙니다. 나중에 1.2.0 돌아가는거 보고 제가 위젯 만들려고 하는거에요. ^^

Mysql query(원리)
select a.member_srl, count(a.point) as count 
from xe_point a, xe_point b
where (
a.point < b.point
or a.member_srl = b.member_srl
)
and 세부 조건...
group by a.member_srl
order by a.point desc limit 0, 10
xe_member 정보까징...
select c.user_id, c.user_name, a.member_srl, count(a.point) as count
from xe_point a, xe_point b, xe_member c
where (
a.point < b.point
or a.member_srl = b.member_srl
)
and a.member_srl = c.member_srl
and 세부 조건...
group by c.user_id, c.user_name, a.member_srl
order by a.point desc limit 0,10

XML query
<query id="getMember" action="select">
    <tables>
        <table name="point" alias="point1" />
        <table name="point" alias="point2" />
    </tables>
    <columns>
        <column name="point1.member_srl" alias="member_srl" />
        <column name="count(point1.point)" alias="point_count" />
    </columns>
    <conditions>
        <group pipe="and">
        <condition operation="below" column="point1.point" default="point2.point" filter="number" pipe="or" />
        <condition operation="equal" column="point1.member_srl" default="point2.member_srl" notnull="notnull" pipe="and" />
        </group>
        <condition operation="equal" column="내용" default="내용" filter="number" pipe="and" />
        ...
    </conditions>
    <groups>
        <group column="point1.member_srl" />
    </groups>
    <navigation>
        <index var="sort_index" default="desc" order="point1.point" />
        <list_count var="list_count" default="20" />
        <page_count var="page_count" default="10" />
        <page var="page" default="1" />
    </navigation>
</query>


공동 순위를 표기할 값을 선언법
이거 원래는 zb4때는 가상테이블 생성 후에 DB로 짜여놓은 후 뽑게 했었는데요.
XE는 가상테이블 생성 같은게 아직 없기 때문에 무리 일 듯 하고요...
어떻게 할지 생각해보다가
1. 전체정보 1번 날려서 순위만 배열로 카운터 시키고 본 출력 시 배열 호출 식으로 할까,
2. 리스트 건당 출력 될 때마다 point 정보로 조회해서 동일한 게 존재하는지 여부로 할까,
어쩔가 고민 중 입니다.

아래 주소는 zb4 때 적용 시켜봤던 공동순위 내용입니다.

http://www.animeclub.net/old/mysql/sql.php

태그 연관 글
  1. [2014/04/09] 묻고답하기 닉네임과 이름 가입시 회원정보 변경시 질문입니다. by xe초보자 *2
  2. [2012/05/17] 묻고답하기 회원정보 팝업창이 안나타나게 하는 방법좀 알려주세요. by 펜잘 *1
  3. [2011/09/01] 묻고답하기 회원DB이전시 비밀번호를 XE로 코딩할수 있나요? by 쿠쿠리~* *2
  4. [2011/07/28] 묻고답하기 회원정보보기 관련.. by 피레느 *1
  5. [2011/03/23] 묻고답하기 회원정보 관련 (( 고수님들 도와주세요 ㅠㅠ )) by 노블진 *1
제목 글쓴이 날짜
회원 순위 공동순위 표시해서 뽑기(원리만 소개) 라르게덴 2009.02.13
주민등록 입력 폼 1.2.0 [55] file 개돌 2009.04.10
개인쪽지발송!~ noirzo 2009.06.23
까오천사님의 만기일 팁을 1.2.4에 맞게 수정했어요. [15] file 도파 2009.08.27
-추가- 당신의 XE 기반 홈페이지를 훅가게 하는 방법 4가지 [26] 老姜君 2009.10.08
Apache,PHP,MySQL,Zend,OpenSSL,PEAR 설치 메모 [1] 엘카 2009.12.03
최신 댓글 보여주는 기능에 관련해 손정호547 2009.12.11
첨부파일이 용량에 따라 등록되기도 하고 안되기도 할 때 해결방법 (웹호스팅) [1] 꽃들 2010.01.02
APM_Setup 7 사용자중에서 첨부 파일 업로드시 100%에서 사라지는 문제 [2] 레드파카 2010.01.04
간단한 시간제한 자료실 만들기 [2] 옥수수밭 2010.03.17
파일 첨부 에러로 고생하시는 분 [2] celli29 2010.05.11
레이아웃 삽입 후 최근 설문조사 가져오기 ilovesyr 2010.05.18
첨부파일 100% 에서 사라지는 문제 저도 해결 [2] 안나오네 2010.06.09
회원확장정보 변수 (출처:sMaker) [5] 시니시즘 2010.07.19
레이아웃 편집, 게시판 상/하단 내용에 위젯 스타일 적용하기 [2] LutZ 2010.09.12
큐브리드(CUBRID) 초보자 학습 자료 및 유용한 링크 정리 file 면스판 2010.11.09
메인화면에 설문조사 위젯(?) 만들기 [3] file 3D매니아 2010.12.14
자동 스크롤 메뉴 (끄기 기능, 무한 스크롤 X) [6] ☺심심 2004.05.02
textarea 입력받는 글자수 제한하는 스크립트 [5] 오기 2002.01.17
문자열 길이(byte)에 따라 자르기... 행복한고니 2002.10.11