mysql에서 기본 키를 설정하는 목적은 다음과 같습니다. 1. 테이블의 엔터티 무결성을 적용할 수 있는 테이블의 각 행을 고유하게 식별합니다. 2. 주로 다른 테이블과의 외래 키 연결 및 수정에 사용됩니다. 이 기록을 삭제합니다.
【관련 학습 권장 사항: mysql 튜토리얼】
mysql에서 기본 키를 설정하는 기능은 다음과 같습니다.
1 기본 키란 무엇입니까
데이터베이스 기본 키는 열을 나타냅니다. 또는 여러 열의 조합으로 인해 테이블의 각 행이 고유하게 식별되며 테이블의 엔터티 무결성이 적용됩니다. 기본 키는 주로 다른 테이블의 외래 키 연결과 이 레코드의 수정 및 삭제에 사용됩니다.
2. 기본 키의 역할
기본 키는 레코드를 결정할 수 있는 고유 식별자이며, 테이블에는 기본 키가 하나만 있을 수 있습니다. 기본 키에는 하나 이상의 필드가 포함될 수 있습니다.
예를 들어, 기록에는 주민등록번호, 이름, 나이, 학교, 국적, 성별 등이 포함됩니다. ID 번호는 귀하를 식별할 수 있는 유일한 번호입니다. 따라서 다른 번호는 중복될 수 있습니다. 따라서 ID 번호가 기본 키입니다.
3. MySQL은 기본 키 없이 테이블을 생성합니다
[root@node110 ~]# mysql -uroot -pyinzhengjie mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 13 Server version: 8.0.14 MySQL Community Server - GPL Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> mysql> mysql> CREATE DATABASE devops CHARACTER SET = utf8; Query OK, 1 row affected, 1 warning (0.00 sec) mysql> mysql> mysql> use devops Database changed mysql> show tables; Empty set (0.00 sec) mysql> mysql> CREATE TABLE students(stu_id INT(11),stu_name VARCHAR(50),gender INT(11)); #首先,我们这里只是创建了一张极为普通的表。 Query OK, 0 rows affected (0.01 sec) mysql> mysql> INSERT INTO students VALUES(1,'jason',10); #插入第一条数据 Query OK, 1 row affected (0.00 sec) mysql> mysql> INSERT INTO students VALUES(2,'danny',20); #插入第二条数据 Query OK, 1 row affected (0.01 sec) mysql> mysql> INSERT INTO students VALUES(1,'jenny',30); #插入第三条数据,注意!这个id和第一条插入的数据是相同的,别问我为什么这么干,我是故意这样搞的! Query OK, 1 row affected (0.00 sec) mysql> mysql> SELECT * FROM students; #我们查询咱们刚刚插入的三条数据 +--------+----------+--------+ | stu_id | stu_name | gender | +--------+----------+--------+ | 1 | jason | 10 | | 2 | danny | 20 | | 1 | jenny | 30 | +--------+----------+--------+ 3 rows in set (0.00 sec) mysql>
4. 기본 키(student_primary)가 있는 테이블을 생성합니다.
mysql> CREATE TABLE student_primary(stu_id INT(11) PRIMARY KEY AUTO_INCREMENT,stu_name VARCHAR(50),gender INT(11)); #仔细一下这个建表语句,除了和上面的表名不同,我还为stu_id字段加了主键属性,以及自动增长的属性! Query OK, 0 rows affected (0.01 sec) mysql> mysql> INSERT INTO student_primary VALUES(1,'json',10); #这里我们插入第一条数据 Query OK, 1 row affected (0.00 sec) mysql> mysql> INSERT INTO student_primary VALUES(2,'danny',20); #这里我们插入第二条数据 Query OK, 1 row affected (0.01 sec) mysql> mysql> INSERT INTO student_primary VALUES(1,'jenny',30); #这里我们插入第三条数据时,报错啦!提示主键重复! ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY' mysql> mysql> mysql> SELECT * FROM student_primary; #我们查看表中的数据,果不其然,只有两条数据!第三条数据没有被插入进来,因为它不符合我们定义的主键规则!主键必须唯一且非空! +--------+----------+--------+ | stu_id | stu_name | gender | +--------+----------+--------+ | 1 | json | 10 | | 2 | danny | 20 | +--------+----------+--------+ 2 rows in set (0.00 sec) mysql>
5. 기본 키가 있는 테이블을 생성합니다(course)
mysql> CREATE TABLE course(id INT(11) PRIMARY KEY AUTO_INCREMENT,course_name VARCHAR(30)); Query OK, 0 rows affected (0.02 sec) mysql> mysql> INSERT INTO course VALUES(1,'Chinese'); #插入第一条数据 Query OK, 1 row affected (0.01 sec) mysql> mysql> INSERT INTO course VALUES(2,'English'); Query OK, 1 row affected (0.00 sec) mysql> INSERT INTO course VALUES(3,'Mathematics'),(4,'Physics'),(5,'Chemistry'),(6,'Biology'); #咱们可以同时插入多条数据 Query OK, 4 rows affected (0.01 sec) Records: 4 Duplicates: 0 Warnings: 0 mysql> mysql> SELECT * FROM course; +----+-------------+ | id | course_name | +----+-------------+ | 1 | Chinese | | 2 | English | | 3 | Mathematics | | 4 | Physics | | 5 | Chemistry | | 6 | Biology | +----+-------------+ 6 rows in set (0.00 sec) mysql>
위 내용은 mysql에서 기본 키를 설정하는 용도는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!