게시판 목록 쿼리 대체하기 > 그누보드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개

전체 3 |RSS

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1402호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT