메뉴 건너뛰기

프로그램언어

2017.03.07 02:59

기본적인 페이징

조회 수 24849 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
<? 
# 
# paging.php 
# 페이징 테스트 파일 
# 

$connect = mysql_connect ( "localhost", "아이디", "패스워드" ) or die ("DB에 연결할 수 없습니다."); 
$status = mysql_select_db("DB명", $connect) or die ("DB 사용 실패 : ".mysql_error($connect)); 

// 페이지 설정 
$page_set = 10; // 한페이지 줄수 
$block_set = 5; // 한페이지 블럭수 

$query = "SELECT count(no) as total FROM board"; 
$result = mysql_query($query, $connect) or die ("쿼리 에러 : ".mysql_error($connect)); 
$row = mysql_fetch_array($result); 

$total = $row[total]; // 전체글수 

$total_page = ceil ($total / $page_set); // 총페이지수(올림함수) 
$total_block = ceil ($total_page / $block_set); // 총블럭수(올림함수) 

if (!$page) $page = 1; // 현재페이지(넘어온값) 
$block = ceil ($page / $block_set); // 현재블럭(올림함수) 

$limit_idx = ($page - 1) * $page_set; // limit시작위치 

// 현재페이지 쿼리 
$query = "SELECT no FROM board ORDER BY no DESC LIMIT $limit_idx, $page_set"; 
$result = mysql_query($query, $connect) or die ("쿼리 에러 : ".mysql_error($connect)); 
$rows = mysql_num_rows($result); 
// 리스트 뿌리기 
echo "<pre>"; 
while ($row = mysql_fetch_array($result)) { 
echo $row[no]."\n"; 
} 
echo "</pre>"; 

// 페이지번호 & 블럭 설정 
$first_page = (($block - 1) * $block_set) + 1; // 첫번째 페이지번호 
$last_page = min ($total_page, $block * $block_set); // 마지막 페이지번호 

$prev_page = $page - 1; // 이전페이지 
$next_page = $page + 1; // 다음페이지 

$prev_block = $block - 1; // 이전블럭 
$next_block = $block + 1; // 다음블럭 

// 이전블럭을 블럭의 마지막으로 하려면... 
$prev_block_page = $prev_block * $block_set; // 이전블럭 페이지번호 
// 이전블럭을 블럭의 첫페이지로 하려면... 
//$prev_block_page = $prev_block * $block_set - ($block_set - 1); 
$next_block_page = $next_block * $block_set - ($block_set - 1); // 다음블럭 페이지번호 

// 페이징 화면 
echo ($prev_page > 0) ? "<a href='$PHP_SELF?page=$prev_page'>[prev]</a> " : "[prev] "; 
echo ($prev_block > 0) ? "<a href='$PHP_SELF?page=$prev_block_page'>...</a> " : "... "; 

for ($i=$first_page; $i<=$last_page; $i++) { 
echo ($i != $page) ? "<a href='$PHP_SELF?page=$i'>$i</a> " : "<b>$i</b> "; 
} 

echo ($next_block <= $total_block) ? "<a href='$PHP_SELF?page=$next_block_page'>...</a> " : "... "; 
echo ($next_page <= $total_page) ? "<a href='$PHP_SELF?page=$next_page'>[next]</a>" : "[next]"; 

?> 


  1. 한글줄바꾸기 또는 utf-8 wordwrap

    Date2014.04.12 Views26546
    Read More
  2. 해당하는 날짜가 그달의 몇주째인지 계산

    Date2014.02.27 Views26351
    Read More
  3. php 세션 유지시간 늘리기

    Date2017.03.07 Views26319
    Read More
  4. 페이지 로딩 시간 측정

    Date2014.02.27 Views26046
    Read More
  5. 환경변수 HTTP_USER_AGENT를 이용해서 스마트 기기 분류하기

    Date2016.09.21 Views25959
    Read More
  6. 디렉토리내 특정 확장자를 가진 파일 전부 삭제

    Date2015.04.14 Views25515
    Read More
  7. 로또 숫자 랜덤하게 1~45까지 숫자 빼오기

    Date2014.02.27 Views25438
    Read More
  8. 홈페이지 귀퉁이에 붙이는 공지창

    Date2015.04.06 Views25426
    Read More
  9. 파일 삭제

    Date2015.04.14 Views25334
    Read More
  10. 한글자르기 substr

    Date2015.04.14 Views25198
    Read More
  11. array (배열)

    Date2015.04.14 Views24904
    Read More
  12. 기본적인 페이징

    Date2017.03.07 Views24849
    Read More
  13. $_SERVER변수

    Date2014.02.27 Views24444
    Read More
  14. 필드값 저장

    Date2014.02.27 Views24276
    Read More
  15. addslashes 함수의 필요성

    Date2015.04.14 Views24250
    Read More
  16. $_SERVER 함수

    Date2016.12.23 Views23943
    Read More
  17. $_FILES

    Date2016.12.23 Views23847
    Read More
  18. [PHP] POST 로 넘어온 모든 변수값 확인하기

    Date2015.03.25 Views23347
    Read More
  19. POST, GET으로 배열값 받기(직렬화)

    Date2017.03.06 Views23286
    Read More
  20. ajax refresh 시키기(자동리플래쉬) with php

    Date2017.03.06 Views23185
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved