Spring/Tistory
블로그-V3. 스칼라 서브 쿼리로 구현한 JPA Pageable
JJJAEOoni
2022. 4. 27. 00:43
반응형
X정리X
SELECT COUNT(*) FROM post WHERE userId = 1;
Integer mTotalPages( );
size = 3;
totalPages = 2; = ceil(전체개수 5라면 / 3)
SELECT ceil(COUNT(*)/3) FROM post WHERE userId = 1;
사이즈 = 3 (상수)
현재 페이지 = 사용자입력 (변수)
전체 페이지 = (사이즈), (전체 게시글 수)
스칼라 서브쿼리 (결과가 한건)
SELECT
3 size,
0 currentPage,
(SELECT COUNT(*) FROM post WHERE userId = 1) totalCount,
(SELECT ceil(COUNT(*)/3) FROM post WHERE userId = 1) totalPages,
p.*
FROM post p
ORDER BY p.id DESC
LIMIT 0*3, 3;
db에서 1이 나오면 true, 0은 false
SQL처럼 데이터만 다루는 언어를 DSL(Domain Specific Language)이라고 한다.
데이터를 다루는데 특화된 언어인 것이다.
토탈 페이지가 2이고
현재 페이지가 0일 때
-- 변수 선언(실행시에 메모리에 띄움)
SET @currentPage = 0;
SELECT
if(@currentPage=0, TRUE, FALSE) FIRST,
if(@currentPage=(SELECT ceil(COUNT(*)/3) FROM post WHERE userId = 1)-1, TRUE, FALSE) LAST,
3 size,
0 currentPage,
(SELECT COUNT(*) FROM post WHERE userId = 1) totalCount,
(SELECT ceil(COUNT(*)/3) FROM post WHERE userId = 1) totalPages,
p.*
FROM post p
ORDER BY p.id DESC
LIMIT 0, 3; -- LIMIT (0*3), 3;
토탈 페이지가 2이고
현재 페이지가 1일 때
* 페이지넘버는 첫번째 페이지가 0이라서 2번째 페이지 넘버가 1이다.
토탈 페이지에 -1 해줘야 정상적으로 돌아간다.
-- 변수 선언(실행시에 메모리에 띄움)
SET @currentPage = 1;
SELECT
if(@currentPage=0, TRUE, FALSE) FIRST,
if(@currentPage=(SELECT ceil(COUNT(*)/3) FROM post WHERE userId = 1)-1, TRUE, FALSE) LAST,
3 size,
0 currentPage,
(SELECT COUNT(*) FROM post WHERE userId = 1) totalCount,
(SELECT ceil(COUNT(*)/3) FROM post WHERE userId = 1) totalPages,
p.*
FROM post p
ORDER BY p.id DESC
LIMIT 0, 3; -- LIMIT (0*3), 3;
쿼리를 직접 만드면 자바 오브젝트에 매핑하는게 귀찮다..
머스태치에서 값을 뿌릴 때 안에 키값이 없을 때 뿌리는 법
{{.}}
바로 값이 찍힌다
반응형