게시판 목록 쿼리 대체하기 > 그누보드5 팁자료실

그누보드5 팁자료실

게시판 목록 쿼리 대체하기 정보

게시판 목록 쿼리 대체하기

본문

코어 부분 변경을 최소화 하면서 목록 뽑는 쿼리를 대체하는 방법.

bbs/list.php 파일에 한 줄을 추가 합니다.
아래 코드는 대략 175라인에 있습니다.


+@include_once("{$board_skin_path}/mutation.list.head.php");
// 페이지의 공지개수가 목록수 보다 작을 때만 실행
if($page_rows > 0) {
    $result = sql_query($sql);


그리고 스킨에 아래와 같은 내용으로 mutation.list.head.php 파일을 추가하고 적절히 쿼리를 변경해서 사용하면 됩니다.

게시글 목록 뽑을 때 여러 테이블을 조인해서 쿼리를 만들어야 하거나 할 때 사용하면 됩니다.


$search_realm = trim($_REQUEST['sfl']);
$search_query = trim($_REQUEST['stx']);
$search_logical = trim($_REQUEST['sop']);
$search_category = trim(urldecode($_REQUEST['sca']));
$on_page = (int) $_REQUEST['page'];

$sql_where = " AND A.wr_is_comment = 0";

switch ($search_realm) {
	case 'wr_subject':
		$sql_where .= " AND INSTR(A.wr_subject, '{$search_query}')";
		break;
	case 'wr_content':
		$sql_where .= " AND INSTR(A.wr_content, '{$search_query}')";
		break;
	case 'wr_subject||wr_content':
		$sql_where .= " AND
			(
				INSTR(A.wr_subject, '{$search_query}')
				OR
				INSTR(A.wr_content, '{$search_query}')
			)";
		break;
}

$sql_where .= empty($search_category) ? '' : " AND A.ca_name = '{$search_category}'";

$sql = "SELECT COUNT(*) AS C
	FROM `{$write_table}` A
	WHERE 1{$sql_where}";
$result = sql_query($sql);
$row = sql_fetch_array($result);

$page_rows -= (int) $notice_count;
$total_count = (int) $row['C'] + (int) $notice_count;
$total_page = ceil($total_count / $page_rows);
$from_record = ((($on_page < 1) ? 1 : $on_page) -1) * $page_rows;

$sql = "SELECT A.*
	FROM `{$write_table}` A
	WHERE 1{$sql_where}{$sql_order}
	LIMIT {$from_record}, {$page_rows}";
추천
0
  • 복사

댓글 2개

© SIRSOFT
현재 페이지 제일 처음으로