테스트 사이트 - 개발 중인 베타 버전입니다

게시판 목록 쿼리 대체하기

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

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

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

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

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

[code]
$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}";
[/code]

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 2개

7년 전
리스트
감사합니다.

게시글 목록

번호 제목
24149
24140
24133
24125
24119
24109
24105
24101
24093
24089
24077
24074
24071
24070
24067
24056
24050
24046
24043
24040
24037
24036
24035
24034
24021
24017
24005
24002
23990
23980