mysql 행 삭제

WBOY
풀어 주다: 2023-05-14 12:27:07
원래의
1594명이 탐색했습니다.

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에서 행 삭제 시 주의사항

  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 절을 사용하여 필터링할 수 있습니다. 예를 들어, 학생이라는 테이블의 남학생 ​​데이터를 모두 삭제하려면 다음 명령문을 사용하면 됩니다.

DELETE FROM student WHERE s_gender = 'M';
로그인 후 복사
  1. Delete a lot of data

테이블에서 많은 양의 데이터를 삭제하려면, 너무 많은 시스템 리소스를 차지하지 않도록 일괄 삭제할 수 있습니다. 예를 들어, 한 번에 1,000개의 행을 삭제하여 학생이라는 테이블에서 실패한 모든 학생 데이터를 삭제하려면 다음 명령문을 사용할 수 있습니다.

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 문을 사용하여 중복 데이터를 제거할 수 있습니다. 예를 들어, 학생이라는 테이블에서 중복된 학생 데이터를 삭제하려면 다음 명령문을 사용할 수 있습니다.
  2. DELETE FROM student
    WHERE s_id NOT IN
    (
        SELECT MAX(s_id) FROM student GROUP BY s_name, s_gender, s_age
    );
    로그인 후 복사
    위는 MySQL에서 행을 삭제하는 방법, 주의 사항 및 적용 예에 대한 소개입니다. 실제 사용에서는 실수로 데이터를 삭제하는 것을 방지하고 시스템 성능과 사용자 경험을 향상시키기 위해 특정 상황에 따라 적절한 삭제 전략을 채택해야 합니다.

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

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