[mysql] INNER JOIN을 사용한 SQL DELETE

2 개의 테이블이 spawnlist있으며 npc,에서 데이터를 삭제해야합니다 spawnlsit.
npc_templateid = n.idTemplate테이블을 “연결”하는 유일한 것입니다. 이 스크립트를 시도했지만 작동하지 않습니다.

나는 이것을 시도했다 :

DELETE s FROM spawnlist s
INNER JOIN npc n ON s.npc_templateid = n.idTemplate
WHERE (n.type = "monster");



답변

추가 .*s당신의 첫 번째 줄에.

시험:

DELETE s.* FROM spawnlist s
INNER JOIN npc n ON s.npc_templateid = n.idTemplate
WHERE (n.type = "monster");


답변

데이터베이스가 InnoDB 인 경우 외래 키를 사용하고 삭제시 캐스케이드하는 것이 더 좋을 수 있습니다. 이렇게하면 원하는 작업을 수행 할 수 있으며 중복 데이터가 저장되지 않습니다.

이 예에서는 첫 번째가 필요하지 않다고 생각합니다.

DELETE s
FROM spawnlist AS s
INNER JOIN npc AS n ON s.npc_templateid = n.idTemplate
WHERE n.type = "monster";

원하는 항목을 확실히 삭제할 수 있도록 삭제하기 전에 행을 선택하는 것이 더 좋습니다.

SELECT * FROM spawnlist
INNER JOIN npc ON spawnlist.npc_templateid = npc.idTemplate
WHERE npc.type = "monster";

http://dev.mysql.com/doc/refman/5.0/en/delete.html 에서 MySQL 삭제 구문을 확인할 수도 있습니다.


답변

데이터베이스가 InnoDB 인 경우 삭제시 조인을 수행 할 필요가 없습니다. 뿐

DELETE FROM spawnlist WHERE spawnlist.type = "monster";

다른 테이블의 외래 키와 연결된 모든 레코드를 삭제하는 데 사용할 수 있습니다. 이렇게하려면 디자인 타임에 먼저 테이블을 연결해야합니다.

CREATE TABLE IF NOT EXIST spawnlist (
  npc_templateid VARCHAR(20) NOT NULL PRIMARY KEY

)ENGINE=InnoDB;

CREATE TABLE IF NOT EXIST npc (
  idTemplate VARCHAR(20) NOT NULL,

  FOREIGN KEY (idTemplate) REFERENCES spawnlist(npc_templateid) ON DELETE CASCADE

)ENGINE=InnoDB;

MyISAM을 사용하는 경우 이와 같이 결합하는 레코드를 삭제할 수 있습니다.

DELETE a,b
FROM `spawnlist` a
JOIN `npc` b
ON a.`npc_templateid` = b.`idTemplate`
WHERE a.`type` = 'monster';

첫 번째 줄에서는 레코드를 삭제하기 위해 두 개의 임시 테이블을 초기화했으며 두 번째 줄에서는 존재 테이블을 a와 b 모두에 할당했지만 여기서는 조인 키워드로 두 테이블을 함께 연결했으며 기본 및 외래 키를 일치 시켰습니다. 링크를 만드는 두 테이블에 대해 마지막 줄에서 삭제할 필드로 레코드를 필터링했습니다.


답변