관리 메뉴

웹개발자의 기지개

[PHP] 유용한 실무팁 6 - 게시글 순서 이동시키기 로직 본문

PHP

[PHP] 유용한 실무팁 6 - 게시글 순서 이동시키기 로직

http://portfolio.wonpaper.net 2024. 3. 7. 02:23

 

 

 

게시글 순서를 위아래로 이동시키는 로직을 간단히 구현해 보자.

order_no 칼럼이 순서값에 해당한다.

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<?
 
$no            = ($_GET['no'])?            $_GET['no']            : $_POST['no'];
$page        = ($_GET['page'])?            $_GET['page']        : $_POST['page'];
$keyword    = ($_GET['keyword'])?        $_GET['keyword']    : $_POST['keyword'];
$search        = ($_GET['search'])?        $_GET['search']        : $_POST['search'];
 
$move       = $_GET['move'];
 
$query = "select * from board_vod where no=$no";
$res   = mysqli_query($conn,$query) or die("정보 얻기 실패");
$row   = mysqli_fetch_array($res);
$order_no = $row['order_no'];
 
if ($move=="up") {
 
    $query = "select order_no,no from board_vod where order_no > $order_no order by order_no ASC limit 1 ";
    $res1  = mysqli_query($conn,$query) or die("정보1 얻기 실패");
    $row1  = mysqli_fetch_array($res1);
    $order_no1 = $row1['order_no'];
    $no1       = $row1['no'];
    if ($order_no1) {
        
        mysqli_query($conn,"update board_vod Set order_no='$order_no1' where no=$no") or die("정보1_1 변경 실패");
        mysqli_query($conn,"update board_vod Set order_no='$order_no' where no=$no1") or die("정보1_2 변경 실패");
 
        echo "<meta http-equiv='refresh' content='0; url=vod_list.php?page=$page&keyword=$keyword&search=$search'>";
 
    } else {
        
        echo "<script>alert('현재 영상이 최고 순위입니다.');location.href='vod_list.php?page=$page&keyword=$keyword&search=$search';</script>";
        exit;
    }
 
else if ($move=="down") {
 
    $query = "select order_no,no from board_vod where order_no < $order_no order by order_no DESC limit 1 ";
    $res2  = mysqli_query($conn,$query) or die("정보2 얻기 실패");
    $row2  = mysqli_fetch_array($res2);
    $order_no2 = $row2['order_no'];
    $no2       = $row2['no'];
    if ($order_no2) {
        
        mysqli_query($conn,"update board_vod Set order_no='$order_no2' where no=$no") or die("정보2_1 변경 실패");
        mysqli_query($conn,"update board_vod Set order_no='$order_no' where no=$no2") or die("정보2_2 변경 실패");
 
        echo "<meta http-equiv='refresh' content='0; url=vod_list.php?page=$page&keyword=$keyword&search=$search'>";
 
    } else {
        
        echo "<script>alert('현재 영상이 최저 순위입니다.');location.href='vod_list.php?page=$page&keyword=$keyword&search=$search';</script>";
        exit;
    }    
 
}
 
?>
cs

 

$move 값은 up / down 으로 들어온다. 

up 일 경우, 바로 위의 값(order_no1)을 얻어와서 현재 order_no 값과 스위칭한다.  없다면 ' 최고 순위 ' 라고, Alert 시킨다.

down 일 경우, 바로 아래의 값(order_no2)을 얻어와서 현재 order_no 값과 스위칭한다. 없다면 ' 최저 순위 ' 라고  Alert 시킨다.

 

간단하다. 

 

다른 백엔드에서도 이를 이용하면 되겠다.

 

 

 

 

 

Comments