오토세이브 on duplicate key update

오토세이브 on duplicate key update

QA

SIR 제작의뢰 - 견적무료/익명보정/호스팅, DB 이전/단기개발. 이젠 ' 의뢰인'이 원하는 '제작자'에게만 연락처를 알릴 수 있습니다.

오토세이브 on duplicate key update

본문

현재 그누보드가 아닌 일반 게시판을 php로 개발중입니다.

임시저장기능을 만들기 위해 그누보드를 참고하여 on duplicate key update을 이용해 만들고 있는데,

autosave 테이블에 id, table_name(UNI), user_id(UNI), title(UNI), contents, update_dt

이렇게 만들었습니다.

 

제가 의도하는 바는 동일한 table_name, user_id, title 일때는 contents가 update가 되고

table_name, user_id가 같고 title이 다르면 추가로 insert를 시키고 싶습니다.

 

$obj 객체에는 tabile_name, user_id, title, contents, update_dt

 

INSERT INTO autosave (table_name, user_id, title, contents, udt_dt) VALUES ('".$obj->table_name."', '".$obj->user_id."', '".$obj->title."', '".$obj->contents."', '".$obj->update_dt."')  
                                ON DUPLICATE KEY UPDATE title='".$obj->title."', contents='".$obj->contents."', udt_dt='".$obj->update_dt."'

 

이렇게 했는데 다른 title인데도 계속 한 행만 update 되고 있어서 여쭙니다 ㅠ 제가 기능을 잘못 이해하고 있는건가요..?

제가 의도한 대로 하려면 어떻게 해야 할까요?

이 글을 내 페이스북 계정으로 보내기 이 글을 내 트위터 계정으로 보내기 이 글을 내 구글플러스 계정으로 보내기

이 질문에 댓글 쓰기 :

답변 1

채택됨

나시님의 답변

INSERT INTO autosave (table_name, user_id, title, contents, udt_dt) VALUES ('".$obj->table_name."', '".$obj->user_id."', '".$obj->title."', '".$obj->contents."', '".$obj->update_dt."')  
                                ON DUPLICATE KEY UPDATE  contents='".$obj->contents."', udt_dt='".$obj->update_dt."'

 

키를 제외한 나머지만 뒤로 들어갑니다.

 

참고로 뒤쪽에 타이틀까지 썻으니까 table_name, user_id 만 키로 생각하고,  항상 키가 같으니까 - table_name, user_id 는 같으니까요 - 한 행에만 업데이트 하는 거죠 ^^

주소복사
채택됨
답변의 댓글
LovelyCaT님의 댓글
id mediumint(8) unsigned NO PRI
table_name varchar(20) utf8_general_ci NO UNI
user_id mediumint(8) NO UNI
title varchar(200) utf8_general_ci NO UNI
contents blob NO
udt_dt int(10) unsigned YES

이렇게 되어있어요!
 오토세이브 삭제도 있어서 id값은 있어야 합니다 ㅜㅜ
나시님의 댓글
키 구성도 보여주시면 좋은데 키 없이 저렇게만 구성하셨나요?
UNI 는 UNIQUE INDEX 를 뜻하는거라 따로 키로 구성되었다는 뜻은 아닌줄 압니다.
id 를 제외한 나머지 세가지로 구성된 KEY값이 구성되어있는지 확인하셔야 되겠네요
답변을 작성하시기 전에 로그인 해주세요.
전체 54,840 | RSS
고마운 분의 도움으로 질문을 해결하셨다면, 채택을 눌러서 감사의 마음을 전하세요.
어떻게 질문해야 할지 모른다면 질문하는 방법을 읽어 보신후 질문해 보세요.
QA 내용 검색

회원로그인

진행중인 포인트경매

  1. 첨단보안 역해킹과 해커박스

    참여11 회 시작17.12.15 10:22 종료17.12.20 10:22
  2. 홈플러스 모바일 쿠폰 50,000원

    참여79 회 시작17.12.13 22:51 종료17.12.18 22:51

(주)에스아이알소프트 (06253) 서울특별시 강남구 도곡로1길 14, 6층 624호 (역삼동, 삼일프라자) 대표메일:admin@sir.kr
사업자등록번호:217-81-36347 대표:홍석명 통신판매업신고번호:2014-서울강남-02098호 개인정보보호책임자:이총

© SIRSOFT