> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 행을 삭제하는 방법

MySQL에서 행을 삭제하는 방법

WBOY
풀어 주다: 2023-06-03 11:33:33
앞으로
10101명이 탐색했습니다.

1. MySQL의 행 삭제 구문

MySQL에서 행을 삭제하는 구문은 다음과 같습니다.

DELETE FROM table_name WHERE condition(s);
로그인 후 복사

그 중 table_name은 행을 삭제할 테이블의 이름이고, 조건은 다음과 같습니다. 삭제할 행을 필터링하는 조건입니다. AND 또는 OR을 사용하여 여러 조건을 결합할 수 있습니다.

예를 들어, 학생이라는 테이블에서 중학교 번호가 1001인 행을 삭제하려면 다음 명령문을 사용할 수 있습니다.

DELETE FROM student WHERE s_id = 1001;
로그인 후 복사

2. MySQL에서 행 삭제 시 주의사항

  1. 삭제 작업은 주의해서 사용하세요. 복구할 수 없습니다.

삭제 작업은 취소할 수 없으므로 삭제 작업을 수행하기 전에 반드시 확인하세요. 삭제하려는 데이터가 올바른지 확인해야 합니다. 일반적으로 SELECT 문을 사용하여 삭제할 데이터가 예상한 것과 같은지 확인한 후 DELETE 명령을 실행하는 것이 가장 좋습니다.

SELECT * FROM student WHERE s_id = 1001;
DELETE FROM student WHERE s_id = 1001;
로그인 후 복사
  1. WHERE 절의 조건은 고유해야 합니다.

WHERE 절의 조건이 고유하지 않으면 여러 행의 데이터가 삭제됩니다. 실수로 데이터를 삭제하는 것을 방지하려면 DELETE 명령을 사용할 때 데이터의 특성과 요구 사항에 따라 적절한 필터링 조건을 선택해야 합니다.

DELETE FROM student WHERE s_name = '张三';
로그인 후 복사
  1. 삭제 작업은 관련 제약 조건 및 트리거를 트리거합니다.

삭제 작업에 외래 키 제약 조건 및 트리거가 포함되는 경우 시스템은 자동으로 관련 제약 조건 및 트리거를 트리거하고 무결성 검사를 수행합니다. 삭제 작업 중 무결성 규칙을 위반한 경우 삭제 작업이 종료되고 관련 오류 정보가 반환됩니다.

  1. 삭제 작업은 시스템 리소스를 차지하고 성능에 영향을 미칩니다.

많은 삭제 작업을 수행하면 시스템 리소스가 점유되어 시스템 성능과 사용자 경험에 영향을 줄 수 있습니다. 삭제 효율성을 높이고 리소스 사용량을 줄이기 위해서는 상황에 따라 가장 적절한 삭제 전략을 선택해야 합니다.

3. MySQL에서 행을 삭제하는 예제

다음은 MySQL에서 행을 삭제하는 몇 가지 예제를 소개합니다.

  1. 빈 테이블 삭제

테이블에 더 이상 유효한 데이터가 없으면 DELETE 명령을 통해 모든 행을 삭제하여 테이블을 지울 수 있습니다. 예를 들어, 학생이라는 테이블의 모든 행을 삭제하려면 다음 문을 사용할 수 있습니다.

DELETE FROM student;
로그인 후 복사
  1. 조건을 충족하는 데이터의 일부를 삭제하세요

WHERE 절을 사용하여 조건을 충족하는 테이블 데이터를 삭제하려면 필터링하세요. 특정 조건. "student"라는 테이블에서 모든 남학생 데이터를 삭제하려면 다음 명령문을 사용합니다.

DELETE FROM student WHERE s_gender = 'M';
로그인 후 복사
  1. 대량 데이터 삭제

시스템 리소스의 과도한 사용을 피하기 위해 대량의 데이터를 삭제할 수 있습니다. 테이블의 데이터를 일괄 삭제합니다. 예를 들어, 한 번에 1000개의 행을 삭제하여 학생이라는 테이블에서 실패한 모든 학생 데이터를 삭제하려면 다음 문을 사용할 수 있습니다.

WHILE (SELECT COUNT(*) FROM student WHERE s_score < 60) > 0
DO
    DELETE FROM student WHERE s_score < 60 LIMIT 1000;
END WHILE;
로그인 후 복사
  1. Delete DELETE 및 ORDER BY 문을 사용하여 삭제합니다. 다음 명령문을 사용하여 "student"

    DELETE FROM student
    WHERE s_id NOT IN
    (
        SELECT MAX(s_id) FROM student GROUP BY s_name, s_gender, s_age
    );
    로그인 후 복사
    테이블에서 중복된 학생 데이터를 삭제할 수 있습니다.

    위 내용은 MySQL에서 행을 삭제하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿