Notice
Recent Posts
Recent Comments
Tags
- ViewData
- SSD 복사
- 강제이동
- asp.net dropdownlist
- TempData
- 파일업로드 유효성체크
- ViewBag
- jquery 바코드
- XSS방어
- asp.net core Select
- 파일업로드 체크
- XSS PHP
- javascript redirection
- 바코드 생성하기
- ASP.Net Core 404
- javascript 유효성체크
- 하드 마이그레이션
- 하드 윈도우 복사
- Mac Oracle
- 맥 오라클설치
- 말줄임표시
- 404에러페이지
- php 캐쉬제거
- 타임피커
- javascript 바코드 생성
- jquery 바코드생성
- javascript 바코드스캔
- django 엑셀불러오기
- 바코드 스캔하기
- asp.net Select
웹개발자의 기지개
[PHP] 유용한 실무팁 6 - 게시글 순서 이동시키기 로직 본문
게시글 순서를 위아래로 이동시키는 로직을 간단히 구현해 보자.
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 시킨다.
간단하다.
다른 백엔드에서도 이를 이용하면 되겠다.
'PHP' 카테고리의 다른 글
[PHP] 네이버 스마트에디터2 - 413 Request Entity Too Large 에러날때 (0) | 2024.03.21 |
---|---|
[PHP] 특정 특수문자와 영문만 남기고 다른 문자열 제거하기 (0) | 2024.03.07 |
[PHP] 사이트가 죽었는지 확인하기 Curl 이용 (0) | 2023.11.24 |
[PHP] 카카오 로그인 ( with 네이버 로그인 ) (0) | 2023.08.10 |
[PHP] 유용한 실무팁5 - 2단계 메뉴에 따른 Url 주소와 매핑하기 (0) | 2023.05.16 |
Comments