메뉴 건너뛰기

프로그램언어

2017.03.07 02:59

기본적인 페이징

조회 수 24853 추천 수 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. ajax refresh 시키기(자동리플래쉬) with php

    Date2017.03.06 Views23188
    Read More
  2. POST, GET으로 배열값 받기(직렬화)

    Date2017.03.06 Views23296
    Read More
  3. [PHP] POST 로 넘어온 모든 변수값 확인하기

    Date2015.03.25 Views23349
    Read More
  4. $_FILES

    Date2016.12.23 Views23851
    Read More
  5. $_SERVER 함수

    Date2016.12.23 Views23948
    Read More
  6. addslashes 함수의 필요성

    Date2015.04.14 Views24258
    Read More
  7. 필드값 저장

    Date2014.02.27 Views24284
    Read More
  8. $_SERVER변수

    Date2014.02.27 Views24454
    Read More
  9. 기본적인 페이징

    Date2017.03.07 Views24853
    Read More
  10. array (배열)

    Date2015.04.14 Views24908
    Read More
  11. 한글자르기 substr

    Date2015.04.14 Views25206
    Read More
  12. 파일 삭제

    Date2015.04.14 Views25336
    Read More
  13. 홈페이지 귀퉁이에 붙이는 공지창

    Date2015.04.06 Views25430
    Read More
  14. 로또 숫자 랜덤하게 1~45까지 숫자 빼오기

    Date2014.02.27 Views25441
    Read More
  15. 디렉토리내 특정 확장자를 가진 파일 전부 삭제

    Date2015.04.14 Views25519
    Read More
  16. 환경변수 HTTP_USER_AGENT를 이용해서 스마트 기기 분류하기

    Date2016.09.21 Views25961
    Read More
  17. 페이지 로딩 시간 측정

    Date2014.02.27 Views26048
    Read More
  18. php 세션 유지시간 늘리기

    Date2017.03.07 Views26342
    Read More
  19. 해당하는 날짜가 그달의 몇주째인지 계산

    Date2014.02.27 Views26353
    Read More
  20. 한글줄바꾸기 또는 utf-8 wordwrap

    Date2014.04.12 Views26547
    Read More
Board Pagination Prev 1 ... 8 9 10 11 12 13 14 15 16 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved