게시판 목록 쿼리 대체하기 정보
게시판 목록 쿼리 대체하기- KeepItSimpleStyle 자기소개 아이디로 검색 회원게시물
- 6,331
본문
코어 부분 변경을 최소화 하면서 목록 뽑는 쿼리를 대체하는 방법.
bbs/list.php 파일에 한 줄을 추가 합니다.
아래 코드는 대략 175라인에 있습니다.
그리고 스킨에 아래와 같은 내용으로 mutation.list.head.php 파일을 추가하고 적절히 쿼리를 변경해서 사용하면 됩니다.
게시글 목록 뽑을 때 여러 테이블을 조인해서 쿼리를 만들어야 하거나 할 때 사용하면 됩니다.
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
0
댓글 2개
리스트
감사합니다.