안녕하세요,
게시판 프로그램을 작성하다 보니, 페이징 처리를 하게 되면서 큐브리드에는 이런게 없는지 궁금해 문의드립니다.
게시판 로직에서는 전체 게시물의 수를 획득해 와 전체 몇개의 페이지가 있는지 보여주고,
현재 페이지에서 보여줄 데이터만 또 획득해 보여주게 됩니다.
가령 아래와 같이 보통은 처리할텐 데요,
(1) 총 게시물 : SELECT COUNT(uid) FROM board
(2) 현재 페이지의 게시물 : SELECT * FROM board WHERE rownum between 1 and 10
그런데, 저 같은 경우 MySQL을 사용할 때 아래와 같이 했습니다.
(1) 현재 페이지의 게시물 : SELECT SQL_CALC_FOUND_ROWS * FROM board LIMIT 0, 10
(2) 총 게시물 수 : SELECT FOUND_ROWS()
MySQL의 SQL_CALC_FOUND_ROWS는 LIMIT 을 통해 가져오게 되는 결과 셋이 정리되기 전의
총 결과 개수를 기억시키는 키워드입니다.
그리고 상기 쿼리가 실행 된 이후 FOUND_ROWS() 라는 함수를 통해 전체 갯수를 획득할 수 있게 됩니다.
때문에 코드 상의 라인도 줄일 수 있고, 전체 갯수를 구하는 쿼리를 따로 작성하지 않아도 되어 좋은 점이 있습니다.
이와 같이 ROWNUM / ORDERBY_NUM() / GROUPBY_NUM() 을 통해 결과를 추려내기 전의 전체 갯수를
해당 쿼리 실행 이후 알 수 있는 방법이 있을 까요?
도움말을 좀 찾아보고는 있는데 이러한 내용이 눈에 띄지는 않아 문의드려봅니다.
그럼 수고하세요 :)
게시판 프로그램을 작성하다 보니, 페이징 처리를 하게 되면서 큐브리드에는 이런게 없는지 궁금해 문의드립니다.
게시판 로직에서는 전체 게시물의 수를 획득해 와 전체 몇개의 페이지가 있는지 보여주고,
현재 페이지에서 보여줄 데이터만 또 획득해 보여주게 됩니다.
가령 아래와 같이 보통은 처리할텐 데요,
(1) 총 게시물 : SELECT COUNT(uid) FROM board
(2) 현재 페이지의 게시물 : SELECT * FROM board WHERE rownum between 1 and 10
그런데, 저 같은 경우 MySQL을 사용할 때 아래와 같이 했습니다.
(1) 현재 페이지의 게시물 : SELECT SQL_CALC_FOUND_ROWS * FROM board LIMIT 0, 10
(2) 총 게시물 수 : SELECT FOUND_ROWS()
MySQL의 SQL_CALC_FOUND_ROWS는 LIMIT 을 통해 가져오게 되는 결과 셋이 정리되기 전의
총 결과 개수를 기억시키는 키워드입니다.
그리고 상기 쿼리가 실행 된 이후 FOUND_ROWS() 라는 함수를 통해 전체 갯수를 획득할 수 있게 됩니다.
때문에 코드 상의 라인도 줄일 수 있고, 전체 갯수를 구하는 쿼리를 따로 작성하지 않아도 되어 좋은 점이 있습니다.
이와 같이 ROWNUM / ORDERBY_NUM() / GROUPBY_NUM() 을 통해 결과를 추려내기 전의 전체 갯수를
해당 쿼리 실행 이후 알 수 있는 방법이 있을 까요?
도움말을 좀 찾아보고는 있는데 이러한 내용이 눈에 띄지는 않아 문의드려봅니다.
그럼 수고하세요 :)