mysql의 외래 키는 무엇입니까?
MySQL에서 외래 키는 두 테이블의 데이터 간의 연결을 설정하고 강화하는 데 사용되는 하나 이상의 열입니다. 이는 한 테이블의 필드가 다른 테이블의 필드에서 참조된다는 것을 나타냅니다. 외래 키는 관련 테이블의 데이터에 제한을 두어 MySQL이 참조 무결성을 유지할 수 있도록 합니다.
이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터.
외래 키는 기본 키에 상대적입니다.
기본 키 테이블의 행을 고유하게 식별하는 속성 또는 속성 그룹입니다. 테이블에는 기본 키가 하나만 있을 수 있지만 후보 인덱스는 여러 개 있을 수 있습니다. 기본 키는 데이터 불일치를 방지하기 위해 외래 키와 함께 참조 무결성 제약 조건을 형성하는 경우가 많습니다. 기본 키를 사용하면 레코드가 고유하고 기본 키 필드가 비어 있지 않은지 확인할 수 있습니다. 데이터베이스 관리 시스템은 기본 키에 대한 고유 인덱스를 자동으로 생성하므로 기본 키도 특수 인덱스입니다.
외래 키는 두 테이블의 데이터 간의 연결을 설정하고 강화하는 데 사용되는 하나 이상의 열입니다. 외래 키는 한 테이블의 필드가 다른 테이블의 필드에서 참조된다는 의미입니다. 외래 키는 관련 테이블의 데이터에 제한을 두어 MySQL이 참조 무결성을 유지할 수 있도록 합니다.
외래 키 제약 조건은 주로 두 테이블 간의 데이터 일관성을 유지하는 데 사용됩니다. 즉, 한 테이블의 외래 키는 다른 테이블의 기본 키가 되고, 외래 키는 두 테이블을 연결하는 역할을 합니다. 일반적인 상황에서 테이블의 기본 키를 삭제하려면 먼저 다른 테이블에 동일한 외래 키가 없는지 확인해야 합니다. 즉, 테이블의 기본 키에 연결된 외래 키가 없는지 확인해야 합니다.
외래 키를 정의할 때 다음 규칙을 준수해야 합니다.
메인 테이블은 데이터베이스에 이미 존재하거나 현재 생성 중인 테이블이어야 합니다. 후자의 경우 마스터 테이블과 슬레이브 테이블이 동일한 테이블인 경우, 이러한 테이블을 자기 참조 테이블이라고 하며, 이러한 구조를 자기 참조 무결성이라고 합니다.
기본 테이블에 대한 기본 키를 정의해야 합니다.
기본 키에는 null 값이 포함될 수 없지만 외래 키에는 null 값이 허용됩니다. 즉, null이 아닌 모든 외래 키 값이 지정된 기본 키에 나타나는 한 외래 키의 내용은 정확합니다.
메인 테이블의 테이블 이름 뒤에 컬럼 이름을 지정하거나 컬럼 이름의 조합을 지정하세요. 이 열 또는 열 조합은 기본 테이블의 기본 키 또는 후보 키여야 합니다.
외래 키의 열 수는 기본 테이블의 기본 키의 열 수와 동일해야 합니다.
외래 키에 있는 열의 데이터 유형은 기본 테이블의 기본 키에 있는 해당 열의 데이터 유형과 동일해야 합니다.
외래 키 생성
MySQL 외래 키 생성 구문
다음 구문은 CREATE TABLE
문의 하위 테이블에 외래 키를 정의하는 방법을 보여줍니다. CREATE TABLE
语句中的子表中定义外键。
1 2 3 4 5 |
|
下面我们来更详细的查看上面语法:
CONSTRAINT
子句允许您为外键约束定义约束名称。如果省略它,MySQL将自动生成一个名称。FOREIGN KEY
子句指定子表中引用父表中主键列的列。您可以在FOREIGN KEY
子句后放置一个外键名称,或者让MySQL为您创建一个名称。 请注意,MySQL会自动创建一个具有foreign_key_name
名称的索引。REFERENCES
子句指定父表及其子表中列的引用。 在FOREIGN KEY
和REFERENCES
中指定的子表和父表中的列数必须相同。ON DELETE
子句允许定义当父表中的记录被删除时,子表的记录怎样执行操作。如果省略ON DELETE
子句并删除父表中的记录,则MySQL将拒绝删除子表中相关联的数据。此外,MySQL还提供了一些操作,以便您可以使用其他选项,例如ON DELETE CASCADE,当删除父表中的记录时,MySQL可以删除子表中引用父表中记录的记录。 如果您不希望删除子表中的相关记录,请改用ON DELETE SET NULL
操作。当父表中的记录被删除时,MySQL会将子表中的外键列值设置为NULL
,条件是子表中的外键列必须接受NULL
值。 请注意,如果使用ON DELETE NO ACTION
或ON DELETE RESTRICT
操作,MySQL将拒绝删除。ON UPDATE
子句允许指定在父表中的行更新时,子表中的行会怎样执行操作。当父表中的行被更新时,可以省略ON UPDATE
子句让MySQL拒绝对子表中的行的任何更新。ON UPDATE CASCADE
操作允许您执行交叉表更新,并且当更新父表中的行时,ON UPDATE SET NULL
操作会将子表中行中的值重置为NULL
值。ON UPDATE NO ACTION
或UPDATE RESTRICT
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE DATABASE IF NOT EXISTS dbdemo;
USE dbdemo;
CREATE TABLE categories(
cat_id int not null auto_increment primary key,
cat_name varchar(255) not null,
cat_description text
) ENGINE=InnoDB;
CREATE TABLE products(
prd_id int not null auto_increment primary key,
prd_name varchar(355) not null,
prd_price decimal,
cat_id int not null,
FOREIGN KEY fk_cat(cat_id)
REFERENCES categories(cat_id)
ON UPDATE CASCADE
ON
DELETE
RESTRICT
)ENGINE=InnoDB;
로그인 후 복사로그인 후 복사위 구문을 더 자세히 살펴보겠습니다.
- 首先,指定要从中删除外键的表名称。
- 其次,将约束名称放在
DROP FOREIGN KEY
子句之后。
CONSTRAINT
절을 사용하면 외래 키 제약 조건에 대한 제약 조건 이름을 정의할 수 있습니다. 생략하면 MySQL이 자동으로 이름을 생성합니다. FOREIGN KEY
절은 상위 테이블의 기본 키 열을 참조하는 하위 테이블의 열을 지정합니다. FOREIGN KEY
절 뒤에 외래 키 이름을 배치하거나 MySQL이 자동으로 이름을 생성하도록 할 수 있습니다. MySQL은 foreign_key_name
이라는 이름의 인덱스를 자동으로 생성합니다.
REFERENCES
절은 상위 테이블과 해당 하위 테이블의 열에 대한 참조를 지정합니다. FOREIGN KEY
및 REFERENCES
에 지정된 하위 테이블과 상위 테이블의 열 수가 동일해야 합니다. 🎜🎜 ON DELETE
절을 사용하면 상위 테이블의 레코드가 삭제될 때 하위 테이블의 레코드가 작업을 수행하는 방법을 정의할 수 있습니다. ON DELETE
절을 생략하고 상위 테이블의 레코드를 삭제하면 MySQL은 하위 테이블의 관련 데이터 삭제를 거부합니다. 또한 MySQL은 상위 테이블의 레코드를 삭제할 때 🎜ON DELETE CASCADE🎜와 같은 추가 옵션을 사용할 수 있도록 몇 가지 작업도 제공합니다. MySQL은 상위 테이블의 레코드를 참조하는 하위 테이블의 레코드를 삭제할 수 있습니다. 하위 테이블에서 관련 레코드를 삭제하지 않으려면 대신 ON DELETE SET NULL
작업을 사용하세요. 상위 테이블의 레코드가 삭제되면 MySQL은 하위 테이블의 외래 키 열이 NULL</을 허용해야 하는 경우 하위 테이블의 외래 키 열 값을 <code>NULL
로 설정합니다. 코드> >값. ON DELETE NO ACTION
또는 ON DELETE RESTRICT
작업이 사용되는 경우 MySQL은 삭제를 거부합니다. 🎜🎜 ON UPDATE
절을 사용하면 상위 테이블의 행이 업데이트될 때 하위 테이블의 행에 어떤 일이 발생하는지 지정할 수 있습니다. 상위 테이블의 행이 업데이트될 때 MySQL이 하위 테이블의 행에 대한 모든 업데이트를 거부하도록 ON UPDATE
절을 생략할 수 있습니다. ON UPDATE CASCADE
작업을 사용하면 크로스탭 업데이트를 수행할 수 있으며, 상위 테이블의 행이 업데이트되면 ON UPDATE SET NULL
작업이 행의 값을 재설정합니다. 하위 테이블에 NULL
값이 있습니다. ON UPDATE NO ACTION
또는 UPDATE RESTRICT
작업은 모든 업데이트를 거부합니다. 🎜🎜🎜🎜MySQL 테이블 외래 키 생성 예🎜🎜以下示例创建一个dbdemo
数据库和两个表:categories
和products
。每个类别都有一个或多个产品,每个产品只属于一个类别。 products
表中的cat_id
字段被定义为具有UPDATE ON CASCADE
和DELETE ON RESTRICT
操作的外键。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
添加外键
MySQL添加外键语法
要将外键添加到现有表中,请使用ALTER TABLE
语句与上述外键定义语法:
1 2 3 4 5 6 |
|
MySQL添加外键示例
现在,我们添加一个名为vendors
的新表,并更改products
表以包含供应商ID
字段:
1 2 3 4 5 6 7 8 9 |
|
要在products
表中添加外键,请使用以下语句:
1 2 3 4 5 |
|
现在,products
表有两个外键,一个是引用categories
表,另一个是引用vendors
表。
删除MySQL外键
您还可以使用ALTER TABLE
语句将外键删除,如下语句:
1 2 |
|
在上面的声明中:
请注意,
constraint_name
是在创建或添加外键到表时指定的约束的名称。 如果省略它,MySQL会为您生成约束名称。
要获取生成的表的约束名称,请使用SHOW CREATE TABLE
语句,如下所示:
1 |
|
例如,要查看products
表的外键,请使用以下语句:
1 |
|
以下是语句的输出:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
products
表有两个外键约束:products_ibfk_1
和products_ibfk_2
。
可以使用以下语句删除products
表的外键:
1 2 3 4 5 |
|
MySQL禁用外键检查
有时,因为某种原因需要禁用外键检查(例如将CSV文件中的数据导入表中)非常有用。 如果不禁用外键检查,则必须以正确的顺序加载数据,即必须首先将数据加载到父表中,然后再将数据加载导入到子表中,这可能是乏味的。 但是,如果禁用外键检查,则可以按任何顺序加载导入数据。
除非禁用外键检查,否则不能删除由外键约束引用的表。删除表时,还会删除为表定义的任何约束。
要禁用外键检查,请使用以下语句:
1 |
|
当然,可以使用以下语句启用它:
1 |
|
【相关推荐:mysql视频教程】
위 내용은 mysql의 외래 키는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

Laravel은 웹 응용 프로그램을 쉽게 구축하기위한 PHP 프레임 워크입니다. 설치 : Composer를 사용하여 전 세계적으로 Laravel CLI를 설치하고 프로젝트 디렉토리에서 응용 프로그램을 작성하는 등 다양한 기능을 제공합니다. 라우팅 : Routes/Web.php에서 URL과 핸들러 간의 관계를 정의하십시오. 보기 : 리소스/뷰에서보기를 작성하여 응용 프로그램의 인터페이스를 렌더링합니다. 데이터베이스 통합 : MySQL과 같은 데이터베이스와 상자 외 통합을 제공하고 마이그레이션을 사용하여 테이블을 작성하고 수정합니다. 모델 및 컨트롤러 : 모델은 데이터베이스 엔티티를 나타내고 컨트롤러는 HTTP 요청을 처리합니다.

MySQL 및 Phpmyadmin은 강력한 데이터베이스 관리 도구입니다. 1) MySQL은 데이터베이스 및 테이블을 작성하고 DML 및 SQL 쿼리를 실행하는 데 사용됩니다. 2) PHPMYADMIN은 데이터베이스 관리, 테이블 구조 관리, 데이터 운영 및 사용자 권한 관리에 직관적 인 인터페이스를 제공합니다.

다른 프로그래밍 언어와 비교할 때 MySQL은 주로 데이터를 저장하고 관리하는 데 사용되는 반면 Python, Java 및 C와 같은 다른 언어는 논리적 처리 및 응용 프로그램 개발에 사용됩니다. MySQL은 데이터 관리 요구에 적합한 고성능, 확장 성 및 크로스 플랫폼 지원으로 유명하며 다른 언어는 데이터 분석, 엔터프라이즈 애플리케이션 및 시스템 프로그래밍과 같은 해당 분야에서 이점이 있습니다.

작은 응용 프로그램을 개발할 때 까다로운 문제가 발생했습니다. 가벼운 데이터베이스 운영 라이브러리를 신속하게 통합해야합니다. 여러 라이브러리를 시도한 후에는 기능이 너무 많거나 호환되지 않는다는 것을 알았습니다. 결국, 나는 내 문제를 완벽하게 해결하는 YII2를 기반으로 단순화 된 버전 인 Minii/DB를 발견했습니다.

기사 요약 :이 기사는 Laravel 프레임 워크를 쉽게 설치하는 방법에 대한 독자들을 안내하기위한 자세한 단계별 지침을 제공합니다. Laravel은 웹 애플리케이션의 개발 프로세스를 가속화하는 강력한 PHP 프레임 워크입니다. 이 자습서는 시스템 요구 사항에서 데이터베이스 구성 및 라우팅 설정에 이르기까지 설치 프로세스를 다룹니다. 이러한 단계를 수행함으로써 독자들은 라벨 프로젝트를위한 탄탄한 토대를 빠르고 효율적으로 놓을 수 있습니다.

Thelia를 사용하여 전자 상거래 웹 사이트를 개발할 때 까다로운 문제가 발생했습니다. MySQL 모드가 제대로 설정되지 않아 일부 기능이 제대로 작동하지 않습니다. 약간의 탐색 후, 나는 theliamysqlmodeschecker라는 모듈을 발견했습니다.이 모듈은 Thelia가 요구하는 MySQL 패턴을 자동으로 수정하여 내 문제를 완전히 해결할 수 있습니다.

MySQL은 테이블 구조 및 SQL 쿼리를 통해 구조화 된 데이터를 효율적으로 관리하고 외래 키를 통해 테이블 간 관계를 구현합니다. 1. 테이블을 만들 때 데이터 형식을 정의하고 입력하십시오. 2. 외래 키를 사용하여 테이블 간의 관계를 설정하십시오. 3. 인덱싱 및 쿼리 최적화를 통해 성능을 향상시킵니다. 4. 데이터 보안 및 성능 최적화를 보장하기 위해 데이터베이스를 정기적으로 백업 및 모니터링합니다.

MySQL은 웹 개발에 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 주요 기능에는 다음이 포함됩니다. 1. 다른 시나리오에 적합한 InnoDB 및 MyISAM과 같은 여러 스토리지 엔진을 지원합니다. 2.로드 밸런싱 및 데이터 백업을 용이하게하기 위해 마스터 슬레이브 복제 기능을 제공합니다. 3. 쿼리 최적화 및 색인 사용을 통해 쿼리 효율성을 향상시킵니다.
