MySQL에서 LEFT JOIN을 사용하여 행 삭제
MySQL에서 LEFT JOIN을 생성하는 것은 여러 테이블에서 데이터를 검색하는 강력한 도구가 될 수 있습니다. 그러나 DELETE 작업에 동일한 LEFT JOIN 구문을 사용하려고 하면 모호함과 오류가 발생할 수 있습니다.
문제
"기한"이 있는 시나리오를 고려해보세요. " 테이블과 "작업" 테이블이 있습니다. 각 작업에는 상태가 있으며 특정 상태는 관련 기한을 삭제해야 함을 나타냅니다. LEFT JOIN을 사용하여 원하는 행을 선택할 수 있습니다.
SELECT * FROM `deadline` LEFT JOIN `job` ON deadline.job_id = job.job_id WHERE `status` = 'szamlazva' OR `status` = 'szamlazhato' OR `status` = 'fizetve' OR `status` = 'szallitva' OR `status` = 'storno'
그러나 동일한 LEFT JOIN 구문을 사용하여 이러한 행을 삭제하려고 하면:
DELETE FROM `deadline` LEFT JOIN `job` ON deadline.job_id = job.job_id WHERE `status` = 'szamlazva' OR `status` = 'szamlazhato' OR `status` = 'fizetve' OR `status` = 'szallitva' OR `status` = 'storno'
MySQL에서 오류가 발생합니다. .
해결 방법
행을 성공적으로 삭제하려면 영향을 받을 테이블을 명시적으로 지정해야 합니다. DELETE 키워드 앞에 테이블 이름을 배치하면 됩니다.
마감일 행만 삭제
마감일 행만 삭제하려면 다음 쿼리를 사용하세요.
DELETE `deadline` FROM `deadline` LEFT JOIN `job` ON deadline.job_id = job.job_id WHERE `status` = 'szamlazva' OR `status` = 'szamlazhato' OR `status` = 'fizetve' OR `status` = 'szallitva' OR `status` = 'storno'
마감일 및 작업 삭제 행
마감일과 작업 행을 모두 삭제하려면 다음 쿼리를 사용하세요.
DELETE `deadline`, `job` FROM `deadline` LEFT JOIN `job` ON deadline.job_id = job.job_id WHERE `status` = 'szamlazva' OR `status` = 'szamlazhato' OR `status` = 'fizetve' OR `status` = 'szallitva' OR `status` = 'storno'
작업 행만 삭제
하려면 작업 행만 삭제하려면 다음 쿼리를 사용하십시오.
DELETE `job` FROM `deadline` LEFT JOIN `job` ON deadline.job_id = job.job_id WHERE `status` = 'szamlazva' OR `status` = 'szamlazhato' OR `status` = 'fizetve' OR `status` = 'szallitva' OR `status` = 'storno'
위 내용은 MySQL에서 LEFT JOIN을 사용하여 행을 어떻게 삭제할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!