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

게시판 목록 쿼리 대체하기

· 9년 전 · 6357 · 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년 전
리스트
감사합니다.

게시글 목록

번호 제목
23798
23797
23792
23791
23785
23781
23770
23766
23764
23761
23747
23732
23724
23718
23706
23700
23697
23686
23682
23681
23680
23678
23665
23644
23643
23639
23637
23630
23626
23616