MySQL 외래 키 캐스케이드 구현 방법
소개
MySQL 외래 키는 제약 조건 역할을 하며 데이터베이스 수준에서 데이터 무결성을 보장합니다.
예를 들어 CASCADE(계단 연결) 유형의 외래 키를 사용하면 하위 테이블(예: user_info)이 상위 테이블(예: user)과 연결될 때 상위 테이블이 업데이트되거나 삭제되면 하위 테이블이 레코드를 업데이트하거나 삭제합니다. 이 프로세스는 데이터베이스 수준에서 완료됩니다.
초기 엔터프라이즈 시스템에는 많은 데이터베이스 설계가 있습니다. 프로그래머가 삭제 및 업데이트 작업을 절약하는 데 도움이 되지만 실제로는 숨겨진 규칙이 증가하고 소프트웨어 복잡성이 증가하며 성능이 저하됩니다.
따라서 애플리케이션 설계에서는 데이터베이스 수준이 아닌 애플리케이션 계층(예: 트랜잭션 처리 메커니즘 사용)에서 데이터 무결성을 보장하기 위해 최선을 다해야 합니다.
다음은 MySQL의 외래키에 대한 소개입니다.
MySQL에서 외래 키를 지원하는 유일한 스토리지 엔진은 InnoDB입니다. 외래 키를 생성할 때 부모 테이블에 해당 색인이 있어야 합니다. 하위 테이블도 자동으로 생성됩니다. 외래 키를 생성할 때 해당 인덱스.
인덱스를 생성할 때
RESTRICT(제한 제한)
NO ACTION
-
SET NULL을 포함하여 상위 테이블을 삭제하거나 업데이트할 때 하위 테이블에서 수행할 해당 작업을 지정할 수 있습니다.
CASCADE(연결)
RESTRICT는 NO ACTION과 동일합니다. 즉, 하위 테이블에 연결된 레코드가 있으면 상위 테이블을 업데이트할 수 없습니다.
CASCADE는 상위 테이블을 의미합니다. 업데이트 또는 삭제됨 하위 테이블의 해당 레코드를 업데이트 또는 삭제하는 경우
SET NULL은 상위 테이블이 업데이트되거나 삭제될 때 하위 테이블의 해당 필드가 SET NULL임을 의미합니다.
Example
InnoDB 엔진만이 외래 키 사용을 허용하므로 데이터 테이블은 InnoDB 엔진을 사용해야 합니다.
데이터베이스 생성:
Create database test;
1. 먼저 두 개의 테이블 stu, sc
create table stu( sid int UNSIGNED primary key auto_increment, name varchar(20) not null) TYPE=InnoDB charset=utf8; create table sc( scid int UNSIGNED primary key auto_increment, sid int UNSIGNED not null, score varchar(20) default '0', index (sid), --外键必须加索引 FOREIGN KEY (sid) REFERENCES stu(sid) ON DELETE CASCADE ON UPDATE CASCADE) TYPE=InnoDB charset=utf8;
– 참고: 외래 키를 색인화해야 합니다.
FOREIGN 키(sid) 외래 키를 설정하고 sid를 외래 키로 설정합니다. REFERENCES stu(sid) 참조 함수입니다. stu 테이블의 sid를 참조하세요
ON DELETE CASCADE cascade delete
ON UPDATE CASCADE cascade update
2. 두 테이블에 데이터를 삽입하세요
insert into stu (name) value ('zxf'); insert into stu (name) value ('ls'); insert into stu (name) value ('zs'); insert into stu (name) value ('ww'); insert into sc(sid,score) values ('1','98'); insert into sc(sid,score) values ('1','98'); insert into sc(sid,score) values ('2','34'); insert into sc(sid,score) values ('2','98'); insert into sc(sid,score) values ('2','98'); insert into sc(sid,score) values ('3','56'); insert into sc(sid,score) values ('4','78'); insert into sc(sid,score) values ('4','98');
참고: sc 테이블에 데이터를 삽입할 때 If sid가 삽입된 경우 22이면 외래 키 sid
캐스케이드 삭제: stu 테이블에서 ID가 2인 학생을 삭제하면 sc 테이블의 학생 성적도 계단식 삭제됩니다.
delete from stu where sid = '2';
캐스케이드 업데이트: stu 테이블에서 ID가 3인 학생이 다음으로 변경됩니다. id는 6이고, sc 테이블에 있는 학생의 해당 id도 업데이트됩니다. cascade
update stu set sid=6 where sid='3';
Note
테이블 삭제 시 외래키 테이블(sc)을 먼저 삭제한 후 삭제해야 합니다. 기본 키 테이블(stu)
위 그림은 외래 키 제약 조건 위반으로 삭제할 수 없음을 보여줍니다.
위 그림은 sc 테이블을 먼저 삭제한 다음 stu 테이블을 삭제하는 정상적인 모습입니다.
위 내용은 MySQL 외래 키 캐스케이드 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL 데이터베이스에서 사용자와 데이터베이스 간의 관계는 권한과 테이블로 정의됩니다. 사용자는 데이터베이스에 액세스 할 수있는 사용자 이름과 비밀번호가 있습니다. 권한은 보조금 명령을 통해 부여되며 테이블은 Create Table 명령에 의해 생성됩니다. 사용자와 데이터베이스 간의 관계를 설정하려면 데이터베이스를 작성하고 사용자를 생성 한 다음 권한을 부여해야합니다.

데이터 통합 단순화 : AmazonRdsMysQL 및 Redshift의 Zero ETL 통합 효율적인 데이터 통합은 데이터 중심 구성의 핵심입니다. 전통적인 ETL (추출, 변환,로드) 프로세스는 특히 데이터베이스 (예 : AmazonRDSMySQL)를 데이터웨어 하우스 (예 : Redshift)와 통합 할 때 복잡하고 시간이 많이 걸립니다. 그러나 AWS는 이러한 상황을 완전히 변경 한 Zero ETL 통합 솔루션을 제공하여 RDSMYSQL에서 Redshift로 데이터 마이그레이션을위한 단순화 된 거의 실시간 솔루션을 제공합니다. 이 기사는 RDSMYSQL ZERL ETL 통합으로 Redshift와 함께 작동하여 데이터 엔지니어 및 개발자에게 제공하는 장점과 장점을 설명합니다.

MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

MySQL 사용자 이름 및 비밀번호를 작성하려면 : 1. 사용자 이름과 비밀번호를 결정합니다. 2. 데이터베이스에 연결; 3. 사용자 이름과 비밀번호를 사용하여 쿼리 및 명령을 실행하십시오.

1. 올바른 색인을 사용하여 스캔 한 데이터의 양을 줄임으로써 데이터 검색 속도를 높이십시오. 테이블 열을 여러 번 찾으면 해당 열에 대한 인덱스를 만듭니다. 귀하 또는 귀하의 앱이 기준에 따라 여러 열에서 데이터가 필요한 경우 복합 인덱스 2를 만듭니다. 2. 선택을 피하십시오 * 필요한 열만 선택하면 모든 원치 않는 열을 선택하면 더 많은 서버 메모리를 선택하면 서버가 높은 부하 또는 주파수 시간으로 서버가 속도가 느려지며, 예를 들어 Creation_at 및 Updated_at 및 Timestamps와 같은 열이 포함되어 있지 않기 때문에 쿼리가 필요하지 않기 때문에 테이블은 선택을 피할 수 없습니다.

Navicat 자체는 데이터베이스 비밀번호를 저장하지 않으며 암호화 된 암호 만 검색 할 수 있습니다. 솔루션 : 1. 비밀번호 관리자를 확인하십시오. 2. Navicat의 "비밀번호 기억"기능을 확인하십시오. 3. 데이터베이스 비밀번호를 재설정합니다. 4. 데이터베이스 관리자에게 문의하십시오.

데이터베이스 산 속성에 대한 자세한 설명 산 속성은 데이터베이스 트랜잭션의 신뢰성과 일관성을 보장하기위한 일련의 규칙입니다. 데이터베이스 시스템이 트랜잭션을 처리하는 방법을 정의하고 시스템 충돌, 전원 중단 또는 여러 사용자의 동시 액세스가 발생할 경우에도 데이터 무결성 및 정확성을 보장합니다. 산 속성 개요 원자력 : 트랜잭션은 불가분의 단위로 간주됩니다. 모든 부분이 실패하고 전체 트랜잭션이 롤백되며 데이터베이스는 변경 사항을 유지하지 않습니다. 예를 들어, 은행 송금이 한 계정에서 공제되지만 다른 계정으로 인상되지 않은 경우 전체 작업이 취소됩니다. BeginTransaction; updateAccountssetBalance = Balance-100WH

다음 명령으로 MySQL 데이터베이스를보십시오. 서버에 연결하십시오. mysql -u username -p password run show database; 기존의 모든 데이터베이스를 가져 오려는 명령 데이터베이스 선택 : 데이터베이스 이름 사용; 보기 테이블 : 테이블 표시; 테이블 구조보기 : 테이블 이름을 설명합니다. 데이터보기 : 테이블 이름에서 *를 선택하십시오.
