MySQL 데이터베이스 관리 시스템은 널리 사용되는 관계형 데이터베이스로, 데이터베이스 운영을 위한 풍부한 SQL 문과 명령 세트를 제공합니다. 그중 DELETE 명령은 하나 이상의 테이블에서 행을 삭제하는 데 사용할 수 있는 일반적인 작업입니다. 이 기사에서는 MySQL에서 행을 삭제하는 방법, 주의 사항 및 실제 응용 프로그램을 소개합니다.
1. MySQL 행 삭제 구문
MySQL에서 행을 삭제하는 구문은 다음과 같습니다.
DELETE FROM table_name WHERE condition(s);
그 중 table_name은 행을 삭제할 테이블 이름이고, Condition(s)은 행을 필터링하는 조건입니다. 행을 삭제할 경우 AND OR을 사용하여 여러 조건을 조인할 수 있습니다.
예를 들어, 학생이라는 테이블에서 중학교 번호가 1001인 행을 삭제하려면 다음 명령문을 사용할 수 있습니다.
DELETE FROM student WHERE s_id = 1001;
2. MySQL에서 행 삭제 시 주의사항
삭제 작업은 되돌릴 수 없으므로 삭제 작업을 수행하기 전에 삭제할 데이터가 올바른지 반드시 확인하세요. 일반적으로 SELECT 문을 사용하여 삭제할 데이터가 예상한 것과 같은지 확인한 후 DELETE 명령을 실행하는 것이 가장 좋습니다.
SELECT * FROM student WHERE s_id = 1001; DELETE FROM student WHERE s_id = 1001;
WHERE 절의 조건이 고유하지 않으면 여러 행의 데이터가 삭제됩니다. 따라서 DELETE 명령을 사용할 때는 데이터 특성에 따라 적절한 필터링 조건을 선택해야 하며, 실수로 데이터를 삭제하는 일이 없도록 해야 합니다.
DELETE FROM student WHERE s_name = '张三';
외래 키 제약 조건 및 트리거가 삭제 작업에 관련된 경우 시스템은 자동으로 관련 제약 조건 및 트리거를 트리거하고 무결성 검사를 수행합니다. 삭제 작업 중 무결성 규칙을 위반한 경우 삭제 작업이 종료되고 관련 오류 정보가 반환됩니다.
많은 삭제 작업을 수행하면 시스템 리소스가 점유되어 시스템 성능과 사용자 경험에 영향을 줄 수 있습니다. 따라서 삭제 작업에 소요되는 자원을 최소화하고 삭제 효율성을 높이기 위해서는 상황에 따라 적절한 삭제 전략을 선택해야 합니다.
3. MySQL에서 행을 삭제하는 예제
다음은 MySQL에서 행을 삭제하는 몇 가지 예제를 소개합니다.
테이블에 더 이상 유효한 데이터가 없으면 DELETE 명령을 통해 모든 행을 삭제하여 테이블을 지울 수 있습니다. 예를 들어, 학생이라는 테이블의 모든 행을 삭제하려면 다음 명령문을 사용할 수 있습니다.
DELETE FROM student;
특정 조건을 충족하는 테이블의 데이터를 삭제하려면, WHERE 절을 사용하여 필터링할 수 있습니다. 예를 들어, 학생이라는 테이블의 남학생 데이터를 모두 삭제하려면 다음 명령문을 사용하면 됩니다.
DELETE FROM student WHERE s_gender = 'M';
테이블에서 많은 양의 데이터를 삭제하려면, 너무 많은 시스템 리소스를 차지하지 않도록 일괄 삭제할 수 있습니다. 예를 들어, 한 번에 1,000개의 행을 삭제하여 학생이라는 테이블에서 실패한 모든 학생 데이터를 삭제하려면 다음 명령문을 사용할 수 있습니다.
WHILE (SELECT COUNT(*) FROM student WHERE s_score < 60) > 0 DO DELETE FROM student WHERE s_score < 60 LIMIT 1000; END WHILE;
DELETE FROM student WHERE s_id NOT IN ( SELECT MAX(s_id) FROM student GROUP BY s_name, s_gender, s_age );
위 내용은 mysql 행 삭제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!