안녕하세요. mysql delete 쿼리 문의 드립니다. 채택완료
안녕하세요.
db에 들어가 있는 product 라는 테이블의 seq 행의 수가 5개가 넘어가면 최근 데이터 행 5개를 남기고 모두 삭제 하여라..
라는 쿼리를 만들고 있습니다.
delete from product order by seq limit 5
이거인데요.. 근데 이거는 지금 기준으로 뒤로 5개 지워라가 되더라구요;;;;
그래서 문의 드립니다.
not in 도 써보고 이것저것 써보는데 쿼리문 만드는데 어려움이 있습니다..
혹시 힌트 주셔도 감사하겠습니다.
답변 2개
채택된 답변
+20 포인트
port443
9년 전
Copy
DELETE FROM product WHERE seq < (SELECT min(seq) FROM (SELECT * FROM product ORDER BY seq LIMIT 0,5) );
로그인 후 평가할 수 있습니다
댓글을 작성하려면 로그인이 필요합니다.
9년 전
자답합니다~
Copy
if($main_seq > 100 ) { $sql = "select seq from product order by seq desc"; $rs=mysql_query($sql); $arr = array(); $index = 1; while($row = mysql_fetch_array($rs)){ $arr[$index]['seq'] = $row['seq']; $index++; } $first = count($arr); for($i=$first;$i>100;$i--){ $seq=$arr[$i]['seq']; $sql= "delete from data where seq=".$seq; $retVal = mysql_query($sql); $sql= "delete from information where seq=".$seq; $retVal = mysql_query($sql); $sql= "delete from product where seq=".$seq; $retVal = mysql_query($sql); }}
로 해결 하였습니다^^;
위에께 안되더라구요;;
로그인 후 평가할 수 있습니다
댓글을 작성하려면 로그인이 필요합니다.
답변을 작성하려면 로그인이 필요합니다.
로그인