Inhaltsverzeichnis
设置表的主键
单字段主键
多字段主键
设置表的外键
设置表的非空约束
设置表的唯一性约束
设置表的属性值自动增加
设置表中属性的默认值
Heim Datenbank MySQL-Tutorial MySQL学习笔记4:完整性约束_MySQL

MySQL学习笔记4:完整性约束_MySQL

Jun 01, 2016 pm 01:37 PM
信息 数据库系统 身份证号码

bitsCN.com

完整性约束是对字段进行限制,从而符合对该属性进行操作的特定要求

通俗点说:如果你的数据不满足我这一字段的要求,数据库系统就拒绝执行操作

 

设置表的主键

主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系

人可以同名,但是身份证号码却是唯一的,

创建主键的目的在于快速查找到表中的某一条信息

 

单字段主键
mysql> create table student(    -> id int primary key,    -> name varchar(20),    -> sex boolean    -> );Query OK, 0 rows affected (0.09 sec)
Nach dem Login kopieren

创建了三个字段,其中id为主键

 

多字段主键

多字段主键由多个属性组合而成,在属性定义完之后统一设置主键

mysql> create table student2(    -> id int,    -> course_id int,    -> score float,    -> primary key(id,course_id)    -> );Query OK, 0 rows affected (0.11 sec)
Nach dem Login kopieren

student2表有三个字段,其中id和course_id的组合可以确定唯一的一条记录

 

设置表的外键

表的外键与主键是相对应的,比如表A中的id是外键,表B中的id是主键

那么就可以称表B为父表,表A为子表

设置表外键的作用在于建立与父表的联系,比如表B中id为123的学生删除后,表A中id为123的记录也随着消失

这样做的目的在于保证表的完整性

mysql> create table student3(    -> id int primary key,    -> course_id int,    -> teacher varchar(20),    -> constraint fk foreign key(id,course_id)    -> references student2(id,course_id)    -> );Query OK, 0 rows affected (0.12 sec)
Nach dem Login kopieren

这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段

references后的内容表示父表,和父表中的主键

需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致

 

设置表的非空约束

非空性很好理解,就是设置表中字段的值不能为空(NULL)

如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错

mysql> create table student4(    -> id int not null,    -> name varchar(20),    -> sex boolean    -> );Query OK, 0 rows affected (0.10 sec)
Nach dem Login kopieren

这里的not null就是约束条件

 

设置表的唯一性约束

唯一性是指表中该字段的值不能重复出现,设置表的唯一性约束

也就是给表中某个字段加上unique

mysql> create table student5(    -> id int unique,    -> name varchar(20)    -> );Query OK, 0 rows affected (0.10 sec)
Nach dem Login kopieren

此处id字段便不可重复

 

设置表的属性值自动增加

auto_increment主要用于为表中插入的新记录自动生成唯一的ID

一个表只能有一个字段使用auto_increment约束

并且该字段必须为主键的一部分

mysql> create table student6(    -> id int primary key auto_increment,    -> name varchar(20)    -> );Query OK, 0 rows affected (0.12 sec)
Nach dem Login kopieren

这里的id是主键,并且会自动增加id值,比如1,2,3,4……

需要注意的是,auto_increment约束的值必须是整数类型

 

设置表中属性的默认值

在表中插入一条新的记录时,如果没有为该字段赋值

那么数据库系统会自动为该字段赋上一条默认值

mysql> create table student7(    -> id int primary key,    -> score int default 0    -> );Query OK, 0 rows affected (0.10 sec)
Nach dem Login kopieren

此处的score字段便会默认为0

 

 

bitsCN.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So entfernen Sie Informationen zum Autor und zur letzten Änderung in Microsoft Word So entfernen Sie Informationen zum Autor und zur letzten Änderung in Microsoft Word Apr 15, 2023 am 11:43 AM

So entfernen Sie Informationen zum Autor und zur letzten Änderung in Microsoft Word

So teilen Sie Kontaktdaten mit NameDrop: Anleitung für iOS 17 So teilen Sie Kontaktdaten mit NameDrop: Anleitung für iOS 17 Sep 16, 2023 pm 06:09 PM

So teilen Sie Kontaktdaten mit NameDrop: Anleitung für iOS 17

So erhalten Sie die GPU in Windows 11 und überprüfen die Grafikkartendetails So erhalten Sie die GPU in Windows 11 und überprüfen die Grafikkartendetails Nov 07, 2023 am 11:21 AM

So erhalten Sie die GPU in Windows 11 und überprüfen die Grafikkartendetails

So verwenden Sie reguläre Python-Ausdrücke zum Extrahieren der ID-Nummer So verwenden Sie reguläre Python-Ausdrücke zum Extrahieren der ID-Nummer Jun 22, 2023 am 10:35 AM

So verwenden Sie reguläre Python-Ausdrücke zum Extrahieren der ID-Nummer

Regulärer PHP-Ausdruck, um zu überprüfen, ob die Eingabezeichenfolge das Format einer ID-Nummer oder einer Passnummer hat Regulärer PHP-Ausdruck, um zu überprüfen, ob die Eingabezeichenfolge das Format einer ID-Nummer oder einer Passnummer hat Jun 24, 2023 pm 12:11 PM

Regulärer PHP-Ausdruck, um zu überprüfen, ob die Eingabezeichenfolge das Format einer ID-Nummer oder einer Passnummer hat

Regulärer PHP-Ausdruck zur Überprüfung der Geburtstagsinformationen der ID-Nummer Regulärer PHP-Ausdruck zur Überprüfung der Geburtstagsinformationen der ID-Nummer Jun 24, 2023 pm 02:22 PM

Regulärer PHP-Ausdruck zur Überprüfung der Geburtstagsinformationen der ID-Nummer

Wie sieht die dreistufige Schemastruktur eines Datenbanksystems aus? Wie sieht die dreistufige Schemastruktur eines Datenbanksystems aus? Jul 23, 2021 pm 03:58 PM

Wie sieht die dreistufige Schemastruktur eines Datenbanksystems aus?

Der Single-View-NeRF-Algorithmus S^3-NeRF verwendet Multi-Beleuchtungsinformationen, um Szenengeometrie und Materialinformationen wiederherzustellen. Der Single-View-NeRF-Algorithmus S^3-NeRF verwendet Multi-Beleuchtungsinformationen, um Szenengeometrie und Materialinformationen wiederherzustellen. Apr 13, 2023 am 10:58 AM

Der Single-View-NeRF-Algorithmus S^3-NeRF verwendet Multi-Beleuchtungsinformationen, um Szenengeometrie und Materialinformationen wiederherzustellen.

See all articles