기본적인 페이징

· 19년 전 · 2385
<?
#
# 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]";

?><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
19년 전 조회 3,193
19년 전 조회 2,266
19년 전 조회 1,954
19년 전 조회 1,632
19년 전 조회 2,082
19년 전 조회 3,365
19년 전 조회 3,235
19년 전 조회 1,910
19년 전 조회 1,484
19년 전 조회 3,183
19년 전 조회 2,055
19년 전 조회 1,620
19년 전 조회 2,841
19년 전 조회 1,972
19년 전 조회 1,842
19년 전 조회 1,816
19년 전 조회 1,785
19년 전 조회 2,208
19년 전 조회 2,630
19년 전 조회 1,789
19년 전 조회 1,526
19년 전 조회 1,535
19년 전 조회 1,462
19년 전 조회 3,226
19년 전 조회 2,916
19년 전 조회 1,671
19년 전 조회 3,408
19년 전 조회 1,834
19년 전 조회 1,485
19년 전 조회 1,950
19년 전 조회 2,094
19년 전 조회 1,628
19년 전 조회 2,335
19년 전 조회 1,989
19년 전 조회 1,600
19년 전 조회 1,782
19년 전 조회 2,035
19년 전 조회 1,785
19년 전 조회 1,589
19년 전 조회 1,654
19년 전 조회 3,121
19년 전 조회 1,992
19년 전 조회 1,862
19년 전 조회 4,363
19년 전 조회 4,994
19년 전 조회 3,153
19년 전 조회 2,887
19년 전 조회 3,490
19년 전 조회 2,036
19년 전 조회 2,386
19년 전 조회 2,684
19년 전 조회 2,759
19년 전 조회 2,346
19년 전 조회 1,607
19년 전 조회 3,375
19년 전 조회 1,972
19년 전 조회 2,382
19년 전 조회 2,446
19년 전 조회 2,871
19년 전 조회 5,201
19년 전 조회 2,481
19년 전 조회 3,322
19년 전 조회 4,264
19년 전 조회 2,501
19년 전 조회 2,456
19년 전 조회 4,025
19년 전 조회 2,742
19년 전 조회 2,989
19년 전 조회 2,198
19년 전 조회 2,217
19년 전 조회 1,998
19년 전 조회 3,277
19년 전 조회 2,111
19년 전 조회 2,785
19년 전 조회 1,742
19년 전 조회 5,311
19년 전 조회 3,560
19년 전 조회 4,311
19년 전 조회 3,057
19년 전 조회 2,520
19년 전 조회 3,923
19년 전 조회 2,647
19년 전 조회 2,986
19년 전 조회 2,950
19년 전 조회 4,173
19년 전 조회 3,119
19년 전 조회 3,019
19년 전 조회 3,676
19년 전 조회 2,974
19년 전 조회 2,201
19년 전 조회 2,223
19년 전 조회 2,162
19년 전 조회 2,767
19년 전 조회 2,479
19년 전 조회 3,344
19년 전 조회 3,195
19년 전 조회 1,824
19년 전 조회 2,738
19년 전 조회 7,824
19년 전 조회 2,498
🐛 버그신고