MySQL学习9:详解MySQL中的外键约束
本篇主要讲解MySQL中的外键约束。 一约束概述 创建约束的目的就是保证数据的完整性和一致性。约束根据约束针对的字段的数目的多少划分为表级约束和列级 约束。 如果约束按照功能来划分的话刻印划分为:NOT NULL(非空约束)、PRIMARYKEY(主键约束)、UNIQUE KEY
本篇主要讲解MySQL中的外键约束。
一约束概述
创建约束的目的就是保证数据的完整性和一致性。约束根据约束针对的字段的数目的多少划分为表级约束和列级
约束。
如果约束按照功能来划分的话刻印划分为:NOT NULL(非空约束)、PRIMARY KEY(主键约束)、UNIQUE
KEY(唯一约束)、DEFAULT(默认约束)和FOREIGN KEY(外键约束)。
在前面我们已经初步涉及到了除外键约束之外的四个约束,这一次我们来谈谈最复杂的外键约束。
二外键约束的要求
FOREIGN KEY(外键约束)
创建外键约束的目的是保持数据一致性,完整性;以及实现一对一或一对多关系。由于外键约束相较于其它四个
约束复杂,因此外键约束的要求有以下:
1)父表和子表必须使用相同的存储引擎,而且禁止使用临时表。说到父表和子表,看看它们的定义:子表指的是
具有外键列的表称为子表;父表指的是子表所参照的表称为父表。
2)数据表的存储引擎只能为InnoDB。3)外键列和参照列必须具有相似的数据类型。其中数字的长度或是否有符号位必须相同;而字符的长度则可以不
同。说到外键列和参照列,先来看看定义:外键列指的是列上加FOREIGN KEY关键字的列称为外键列;参照列指的
是外键列所参照的列称为参照列。
4)外键列和参照列必须创建索引。如果外键不存在索引的话,MySQL将自动创建索引。如果参照列不存在索引的
话,MySQL不会自动创建索引。
三存储引擎
由于创建外键约束需要了解存储引擎,这里只是简单说明一下。
(1)什么是存储引擎
存储引擎也叫表类型,指的是数据表的存储机制、索引方案等配套相关功能。不同引擎由于处理方式不同,会带
来不同的功能或者功能的优化,根据实际需要选择合适的存储引擎。存储引擎类型分为MyISAM与InnoDB。
(2)MyISAM与InnoDB区别
1)InnoDB支持外键,MyISAM不支持。2)MyISAM每个表会生成3个文件: table.MYI(索引文件)、table.MYD(数据文件)、table.frm(表结构文件)
Innodb每个表只有一个table.frm文件,所有的Innodb引擎的表的数据将存放在ibdata*里面。
3)MyISAM支持表级锁,优势在于插入和检索,Innodb支持行级锁,优势在于更新和删除。
4)Innodb支持事务。
(3)编辑数据表的默认存储引擎
1)首先在MySQL安装目录中找到MySQL的配置文件MY.ini,双击打开;
2)查看是否有:default-storage-engine=INNODB
3)修改后需要重新启动MySQL服务,否则不用重新启动。
四创建外键约束
(1)创建一个省份数据表作为父表,然后查看数据表的创建信息确认是否引擎为InnoDB:
CREATE TABLE provinces(
id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
pname VARCHAR(20) NOT NULL
);
SHOW CREATE TABLE provinces;
由此我们保证了创建数据表的时候保证了数据表使用的是默认引擎InnoDB。下面的users表同样也是InnoDB。
(2)使用外键约束创建另一个相似的数据表作为子表。
CREATE TABLE users(
id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(10) NOT NULL,
pid BIGINT,
FOREIGN KEY (pid) REFERENCES provinces (id)
);
以上创建数据表会有错误信息:需要保证数据类型一致。
修改为数据类型一致,默认为有符号位:
CREATE TABLE users(
id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(10) NOT NULL,
pid SMALLINT,
FOREIGN KEY (pid) REFERENCES provinces (id)
);
依然会有错误信息:这一次是是否保持相同的有无符号位。
修改为一致的数据类和是否有符号位:
CREATE TABLE users(
id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(10) NOT NULL,
pid SMALLINT UNSIGNED,
FOREIGN KEY (pid) REFERENCES provinces (id)
);
创建数据表的过程我们知道了子表是users,父表是provinces;子表users中的pid是外键列,父表provinces中的
id字段是参照列。由此我们保证了外键列和参照列必须具有相似的数据类型。
(3)查看外键列和参照列是否创建索引
1)查看父表provinces中的参照列id是否自动创建索引:
SHOW INDEXES FROM provinces;
SHOW INDEXES FROM provinces\G;
以上均表明参照列已经创建索引,我们更习惯看出索引列的是第二种命令,因此一般我们会使用后者。
2)再来查看外键列是否创建索引
SHOW INDEXES FROM users\G;
以上结果表明数据表users存在两个索引列,一个是users表的id字段,一个是外键列pid字段,它的参照列是父表
provinces中的参照列id字段。
我们也可以查看user表中的pid是不是外键列
SHOW CREATE TABLE users;
由此证明users数据表中的pid字段的确是外键约束,经过以上步骤我们成功的使用了外键约束。还有许多关系与
外键约束的操作,我们就不再过多的介绍。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。

数据集成简化:AmazonRDSMySQL与Redshift的零ETL集成高效的数据集成是数据驱动型组织的核心。传统的ETL(提取、转换、加载)流程复杂且耗时,尤其是在将数据库(例如AmazonRDSMySQL)与数据仓库(例如Redshift)集成时。然而,AWS提供的零ETL集成方案彻底改变了这一现状,为从RDSMySQL到Redshift的数据迁移提供了简化、近乎实时的解决方案。本文将深入探讨RDSMySQL零ETL与Redshift集成,阐述其工作原理以及为数据工程师和开发者带来的优势。

要填写 MySQL 用户名和密码,请:1. 确定用户名和密码;2. 连接到数据库;3. 使用用户名和密码执行查询和命令。

1.使用正确的索引索引通过减少扫描的数据量来加速数据检索select*fromemployeeswherelast_name='smith';如果多次查询表的某一列,则为该列创建索引如果您或您的应用根据条件需要来自多个列的数据,则创建复合索引2.避免选择*仅选择那些需要的列,如果您选择所有不需要的列,这只会消耗更多的服务器内存并导致服务器在高负载或频率时间下变慢例如,您的表包含诸如created_at和updated_at以及时间戳之类的列,然后避免选择*,因为它们在正常情况下不需要低效查询se

Navicat本身不存储数据库密码,只能找回加密后的密码。解决办法:1. 检查密码管理器;2. 检查Navicat的“记住密码”功能;3. 重置数据库密码;4. 联系数据库管理员。

数据库ACID属性详解ACID属性是确保数据库事务可靠性和一致性的一组规则。它们规定了数据库系统处理事务的方式,即使在系统崩溃、电源中断或多用户并发访问的情况下,也能保证数据的完整性和准确性。ACID属性概述原子性(Atomicity):事务被视为一个不可分割的单元。任何部分失败,整个事务回滚,数据库不保留任何更改。例如,银行转账,如果从一个账户扣款但未向另一个账户加款,则整个操作撤销。begintransaction;updateaccountssetbalance=balance-100wh

SQLLIMIT子句:控制查询结果行数SQL中的LIMIT子句用于限制查询返回的行数,这在处理大型数据集、分页显示和测试数据时非常有用,能有效提升查询效率。语法基本语法:SELECTcolumn1,column2,...FROMtable_nameLIMITnumber_of_rows;number_of_rows:指定返回的行数。带偏移量的语法:SELECTcolumn1,column2,...FROMtable_nameLIMIToffset,number_of_rows;offset:跳过
