티스토리 뷰


sql = "select b.qna_no from "
sql = sql + "(select rk from "
sql = sql + "(select rank() over(order by qna_ref desc,qna_no) rk,qna_no from tb_opinion "& where &") a "
sql = sql + "where qna_no='"& qna_no &"') aa, "
sql = sql + "(select rank() over(order by qna_ref desc,qna_no) rk,qna_no from tb_opinion "& where &") b "
sql = sql + " where b.rk = aa.rk+1 ;"
'이전글

sql = sql + "select b.qna_no from "
sql = sql + "(select rk from "
sql = sql + "(select rank() over(order by qna_ref desc,qna_no) rk,qna_no from tb_opinion "& where &") a "
sql = sql + "where qna_no='"& qna_no &"') aa, "
sql = sql + "(select rank() over(order by qna_ref desc,qna_no) rk,qna_no from tb_opinion "& where &") b "
sql = sql + " where b.rk = aa.rk-1 ;
'다음글


알고리즘은 간단하다. 게시판 정렬룰과 같은 룰로 랭크를 준다음 그 랭크의 +-1 의 키를 가져오면 되는것이다.

원래는 order by 와 key 의 작고 같음으로 처리 했지만 그럴경우 복잡한 경우의 처리는 하지 못하므로

저런식으로 처리하는게 좋겠다고 판단함. 저런식으로 하면 게시판 룰과 똑같은 형식으로 처리하게 되므로

오차가 생기지 않는다.

디비라고 보기엔 좀 애매해서 웹에 넣어둠.

' > Database' 카테고리의 다른 글

mssql 백업  (0) 2010.04.20
ms-sql 테이블 복사  (0) 2010.02.25
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
TAG
more
«   2024/03   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
글 보관함