首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【重学 MySQL】六十六、外键约束的使用

列匹配:在主表的表名后面指定列名或列名的组合,这个列或列的组合必须是主表的主键。同时,外键中列的数目必须和主表的主键中列的数目相同。 数据类型一致:外键中列的数据类型必须和主表主键列的数据类型相同。...NO ACTION 或 RESTRICT: 含义:这两种约束等级在MySQL中的行为是相似的。它们都会阻止对主表中被引用的记录进行删除或更新操作,如果子表中存在引用该记录的外键记录。...SET DEFAULT: 含义:这个约束等级在MySQL的InnoDB存储引擎中是不被支持的。理论上,它意味着当主表中的记录被删除或更新时,子表中所有引用该记录的外键记录会被设置为一个默认值。...如果希望保留子表中的记录,但将外键字段设置为NULL以表示不再引用主表中的记录,那么可以选择SET NULL约束等级。...例如:在员工表中,可以添加一个员工的信息,它的部门指定为一个完全不存在的部门。 问题3:那么建和不建外键约束和查询有没有关系? 答:没有 在 MySQL 里,外键约束是有成本的,需要消耗系统资源。

13110

【MySQL 系列】MySQL 语句篇_DDL 语句

DELETE 返回删除的行数; 如果一个表被其他表的外键引用,对此表的 TRUNCATE 操作会失败。 2.3、数据列操作 MySQL 允许您使用 ALTER TABLE 语句来修改一个现有的表。...外键相对于主键而言,用来引用其他表。外键通过子表的一个或多个列对应到父表的主键或唯一键值,将子表的行和父表行建立起关联关系。 例如,Sakila 示例数据库中的 country 表和 city 表。...我们可以使用以下 3 个策略中的一个: CASCADE:如果被引用的表中的一行被删除或更新,该表中匹配行的值会自动删除或更新。...SET NULL:如果被引用的表中的一行被删除或更新,该表中匹配行的值设置为 NULL。...RESTRICT: 如果被引用的表中的一行在该表中有匹配的行,试图删除或更新被引用的表中行时会引发 MySQL 错误。这是默认的策略。

32210
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL-多表操作

    SELECT 查询字段 FROM 表1 [INNER] JOIN 表2 ON 匹配条件; ON用于指定内连接的查询条件,在不设置ON时,与交叉连接等价。...但是在MySQL中,CROSS JOIN与INNER JOIN(或JOIN)语法的功能相同,都可以使用ON设置连接的筛选条件,可以互换使用,但是此处不推荐读者将交叉连接与内连接混用 左外连接 左外连接是外连接查询中的一种...在进行其他方式比较时,各条件之间的逻辑关系包含两种情况。 因此,读者在选取行子查询的比较运算符时,要根据实际需求慎重选择。...外键约束 添加外键约束 外键指的是-一个表中引用另一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束, 从而保证数据的一-致性 和完整性。 ➢被引用的表称为主表。...例如,从表外键字段不能插入主表中不存在的数据。

    3.2K20

    索引使用策略及优化

    下图是这个数据库的E-R关系图(引用自MySQL官方手册): ?...在上文中,我们都是假设索引只引用了单个的列,实际上,MySQL中的索引可以以一定顺序引用多个列,这种索引叫做联合索引。...这里特别要说明MySQL一个有意思的地方,那就是仅用explain可能无法区分范围索引和多值匹配,因为在type中这两者都显示为range。...因此在MySQL中要谨慎地区分多值匹配和范围匹配,否则会对MySQL的行为产生困惑。...至于多少条记录才算多,这个个人有个人的看法,我个人的经验是以2000作为分界线,记录数不超过 2000可以考虑不建索引,超过2000条可以酌情考虑索引。 另一种不建议建索引的情况是索引的选择性较低。

    61421

    mysql触发器的作用及语法 转

    比如,在auths表author_code列上的删除触发器可导致对应删除在其他表中的与之匹配的行。   # 在改动或删除时级联改动或删除其他表中的与之匹配的行。   ...# 在改动或删除时把其他表中的与之匹配的行设成NULL值。   # 在改动或删除时把其他表中的与之匹配的行级联设成缺省值。   ...# 触发器可以拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这样的触发器会起作用。...比如,可以在books.author_code 列上生成一个插入触发器,假设新值与auths.author_code列中的某值不匹配时,插入被回退。 5.同步实时地复制表中的数据。...在触发程序的运行过程中,MySQL处理错误的方式例如以下: ·         假设BEFORE触发程序失败,不运行对应行上的操作。

    2K30

    mysql触发器的作用及语法 转

    比如,在auths表author_code列上的删除触发器可导致对应删除在其他表中的与之匹配的行。   # 在改动或删除时级联改动或删除其他表中的与之匹配的行。   ...# 在改动或删除时把其他表中的与之匹配的行设成NULL值。   # 在改动或删除时把其他表中的与之匹配的行级联设成缺省值。   ...# 触发器可以拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这样的触发器会起作用。...比如,可以在books.author_code 列上生成一个插入触发器,假设新值与auths.author_code列中的某值不匹配时,插入被回退。 5.同步实时地复制表中的数据。...在触发程序的运行过程中,MySQL处理错误的方式例如以下: ·         假设BEFORE触发程序失败,不运行对应行上的操作。

    3.5K10

    MySQL(十)操纵表及全文本搜索

    PS:创建新表时,指定的表名必须不存在(如果只想在一个表不存在时创建它,应在表名前给出if not exists:这样做不检查表模式是否与打算创建的表模式匹配,只检查表名是否存在)。...6、引擎类型 MySQL有一个具体管理和处理数据的内部引擎,使用create table语句时,该引擎具体创建表;使用select语句或进行其他数据库处理时,该引擎内部处理请求(引擎隐藏在DBMS内,不需要过多关注...MySQL相比于其他DBMS的区别在于,它具有多种引擎;因为各个引擎有不同的功能和特性,为不同的任务选择正确的引擎能获得良好的功能和灵活性。...检索过程: ①进行一个基本的全文本搜索,找出与搜索条件匹配的所有行; ②MySQL检查这些匹配行并选择所有有用的词(将会简要的解释MySQL如何断定什么有用什么无用); ③MySQL再次进行全文本搜索,...(如果需要,可以覆盖这个列表); ③MySQL50%规则:如果一个词出现在50%以上的行中,则将它作为一个非用词忽略;50%规则不用于in boolean mode; ④如果表中的行数少于3行,则全文本搜索不返回结果

    2K30

    索引使用策略及优化

    ; all:表示此次查询进行了全表扫描(该条SQL需要优化) possible_keys 表示查询中可能使用的索引 如果备选的数量大于3那说明已经太多了,因为太多会导致选择索引而损耗性能, 所以建表时字段最好精简...下图是这个数据库的E-R关系图(引用自MySQL官方手册): MySQL官方文档中关于此数据库的页面为http://dev.mysql.com/doc/employee/en/employee.html...在上文中,我们都是假设索引只引用了单个的列,实际上,MySQL中的索引可以以一定顺序引用多个列,这种索引叫做联合索引,一般的,一个联合索引是一个有序元组,其中各个元素均为数据表的一列,实际上要严格定义索引需要用到关系代数...情况二:最左前缀匹配。 ? 当查询条件精确匹配索引的左边连续一个或几个列时,如或,所以可以被用到,但是只能用到一部分,即条件所组成的最左前缀。...因此在MySQL中要谨慎地区分多值匹配和范围匹配,否则会对MySQL的行为产生困惑。 相关阅读 MySQL索引背后的数据结构及算法原理

    62231

    处理SQLSyntaxErrorException异常:数据库表 ‘books‘ 不存在;

    要解决这个问题,你需要确保在数据库中创建了这个表,或者你需要确保你的代码中引用的表名与实际存在的表名相匹配。...为了解决这个问题,你可以采取以下步骤: 确认数据库中的表名:使用数据库管理工具(例如 MySQL Workbench 或 phpMyAdmin)检查 bookmanagement 数据库以确保表 books...VARCHAR(255) NOT NULL, author VARCHAR(255) NOT NULL -- 添加其他需要的列 ); 更新代码中的引用:如果你的数据库中有一个不同名称的表...通用方法 "Table 'bookmanagement.books' doesn't exist" 错误表明你的Java应用程序尝试访问名为 'books' 的数据库表,但该表在MySQL数据库中并不存在...你可以使用MySQL命令行工具或数据库管理工具来验证数据库和表的存在。 检查表名的大小写:MySQL表名对大小写敏感。确保你在Java代码中使用的表名与数据库中的实际表名大小写一致。

    18710

    mysql触发器的作用及语法

    比如,在auths表author_code列上的删除触发器可导致对应删除在其他表中的与之匹配的行。 # 在改动或删除时级联改动或删除其他表中的与之匹配的行。...# 在改动或删除时把其他表中的与之匹配的行设成NULL值。 # 在改动或删除时把其他表中的与之匹配的行级联设成缺省值。...# 触发器可以拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这样的触发器会起作用。...比如,可以在books.author_code 列上生成一个插入触发器,假设新值与auths.author_code列中的某值不匹配时,插入被回退。 5.同步实时地复制表中的数据。...在触发程序的运行过程中,MySQL处理错误的方式例如以下: · 假设BEFORE触发程序失败,不运行对应行上的操作。

    1.7K10

    110道一线公司Python面试题,推荐收藏

    ,在内存中则会存在不同的对象,即每个对象都有自己的地址,相当于内存中对于同值的对象保存了多份,这里不存在引用计数,是实实在在的对象。...如果表主要是用于插入新记录和读出记录,那么选择MyISAM能实现处理高效率。如果应用的完整性、并发性要求比 较低,也可以使用。 MEMORY:所有的数据都在内存中,数据的处理速度快,但是安全性不高。...如果需要很快的读写速度,对数据的安全性要求较低,可以选择MEMOEY。它对表的大小有要求,不能建立太大的表。所以,这类数据库只使用在相对较小的数据库表。...; 3、InnoDB 支持外键,MyISAM 不支持; 4、对于自增长的字段,InnoDB 中必须包含只有该字段的索引,但是在 MyISAM 表中可以和其他字段一起建立联合索引; 5、清空整个表时,InnoDB...MyISAM 则会重 建表; 87、统计字符串中某字符出现次数 ? 88、字符串转化大小写 ? 89、用两种方法去空格 ? 90、正则匹配不是以4和7结尾的手机号 ?

    2.1K21

    EXPLAIN 使用分析

    SELECT * FROM sys_log 执行计划包含的信息 信息 描述 id 选择标识符 select_type 表示查询的类型 table 输出结果集的表 partitions 匹配的分区...因为只匹配一行数据,所以很快。如将主键置于where列表中,MySQL就能将该查询转换为一个常量。 system: 表中仅有一行,这是const联结类型的一个特例。平时不会出现,这个也可以忽略不计。...key 显示MySQL实际决定使用的键(索引)。 如果没有选择索引,键是NULL。...要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。...ref 列与索引的比较,表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值 rows 根据表统计信息以及索引选用情况,大致估算出找到所需的记录所需要读取的行数 Extra 包含不适合在其他列中显示

    1K20

    110道python面试题

    ,在内存中则会存在不同的对象,即每个对象都有自己的地址,相当于内存中对于同值的对象保存了多份,这里不存在引用计数,是实实在在的对象。...如果表主要是用于插入新记录和读出记录,那么选择MyISAM能实现处理高效率。如果应用的完整性、并发性要求比 较低,也可以使用。 MEMORY:所有的数据都在内存中,数据的处理速度快,但是安全性不高。...如果需要很快的读写速度,对数据的安全性要求较低,可以选择MEMOEY。它对表的大小有要求,不能建立太大的表。所以,这类数据库只使用在相对较小的数据库表。...; 3、InnoDB 支持外键,MyISAM 不支持; 4、对于自增长的字段,InnoDB 中必须包含只有该字段的索引,但是在 MyISAM 表中可以和其他字段一起建立联合索引; 5、清空整个表时,InnoDB...MyISAM 则会重 建表; 87、统计字符串中某字符出现次数 ? 88、字符串转化大小写 ? 89、用两种方法去空格 ? 90、正则匹配不是以4和7结尾的手机号 ?

    2.8K40

    SQL反模式学习笔记15 分组

    目标:查询得到每组的max(或者min等其他聚合函数)值,并且得到这个行的其他字段 反模式:引用非分组列   单值规则:跟在Select之后的选择列表中的每一列,对于每个分组来说都必须返回且仅返回一直值...,无论这个组匹配多少行; Max()等表达式也能保证每组都返回单一的值,即传回参数中的最大值。...如何识别反模式:当输入一个违背了单值规则的查询时,会立刻返回给你一个错误。数据库会返回不同的错误信息。   在SQLite和MySQL中,有歧义的列可能包含不可预测的和不可靠的数据。...2、使用关联子查询:关联子查询会引用外连接查询,并且根据外联结果查询中的每一条记录最终返回不同的结果。...但是数据库必须将临时表得到的记录存在一张临时表中,因此这个方案也不是最好的。   4、使用Join:创建一个联结查询区匹配哪些可能不存在的记录。这样的查询结果被称为外连接查询。

    1.1K30

    三十四、外键约束

    一、参照完整性 参照完整性要求关系中不允许引用不存在的实体。在 MySQL 中设置参照完整性的方式是使用 外键约束 。...所谓外键就是用于在两个表中的数据之间建立和加强链接的一列或多列的组合,可控制可在外键表中存储的数据。例如,有学生表和分数表两个表,表内容如下。...这是因为在学生表中不存在编号为 2021003 的学生,如果想插入成功则必须现在学生表中创建编号为 2021003 这个学生后再向分数表插入这个学生的分数。...外键约束是用于保持主表(父表)和从表(子表)的数据一直。在 MySQL 中只有 InnoDB 存储引擎支持外键约束。...: RESTRICT:拒绝对父表的删除或更新操作; CASCADE:从父表删除或更新时自动删除或更新子表中匹配的行; SET NULL:从父表删除或更新时自动设置子表对应的外键列为NULL; NO ACTION

    1.9K20

    国产数据库兼容过程中涉及的MySQL非严格模式

    在国产数据库兼容适配过程中,经常遇到因源数据库是MySQL,迁移至其他国产数据库后,因MySQL端兼容模式有非严格模式,导致适配过程过程中需要做调整。...在非严格模式下,MySQL会对某些数据插入、更新和比较操作执行隐式转换,从而在一些情况下允许执行一些宽松的操作,而不抛出错误或警告。...,MySQL对外键约束的检查较为宽松,可能会允许插入或更新关联字段中不存在的值。...(建议已开启此类严格模式) eg: tb表外键字段指向ta表的主键,如果tb表的外键字段插入的内容不存在于a表中时也可以写入成功 8) 非严格的除数为0校验:在非严格模式下,MySQL允许除数为0...eg: 10/0 ,结果为null 9) 非严格的字符串引号标识:在非严格模式下,MySQL允许单引号及双引号来引用字符串 eg: 'abc' 或 "abc"均可 10)非严格的grant模式自动创建用户

    36120

    【21】进大厂必须掌握的面试题-65个SQL面试

    左连接: MySQL中的左连接用于返回左表中的所有行,但仅返回右表中满足连接条件的匹配行。 右连接: MySQL中的右连接用于返回右表中的所有行,但仅返回满足连接条件的左表中的匹配行。...子查询也可以使用任何比较运算符,例如>,或=。 Q29。子查询有哪些不同类型? 子查询有两种类型,即”相关”和”不相关”。 相关子查询:这些查询从外部查询中引用的表中选择数据。...命名查询中用于模式匹配的运算符? LIKE运算符用于模式匹配,可以用作-。 %–匹配零个或多个字符。 例如-从学生姓名为’a%’的学生中选择* (下划线)–恰好匹配一个字符。...完成多项操作,例如选择/插入/更新/删除。 Q54。什么是视图? 视图是一个虚拟表,由表中包含的数据子集组成。由于不存在视图,因此占用的空间更少。视图可以合并一个或多个表的数据,这取决于关系。...局部变量: 这些变量只能在函数内部使用或存在。这些变量未被任何其他函数使用或引用。 全局变量: 这些变量是可以在整个程序中访问的变量。每当调用该函数时就无法创建全局变量。 Q62。

    6.9K22

    正则表达式 - 选择、分组和向后引用

    统计单词出现的行数         要对单词 the 出现一次或多次的行的数目进行统计,且不区分大小写。为了更切合数据库的实际应用场景,先给原表增加一个ID主键列。...三、捕获分组和后向引用         当一个模式的全部或者部分内容由一对括号分组时,它就对内容进行捕获并临时存储于内存中。可以通过后向引用引用捕获的内容,形式为 \1 或 1 。...这里 \1 或 1 引用的是第一个捕获的分组,而 \2 或 2 引用第二个捕获的分组,以此类推。MySQL只接受 1 这种形式。         下面再展示一下后向引用的使用方法。...继续走遇到了分支,先用左边的(分支选择是从左到右),abbc 与 abc 匹配失败,则整个匹配失败,不再回溯其他分支。...如果表达式的其余部分不匹配,则正则表达式将返回到先前记录的位置并尝试其他组合。如果使用了原子分组,则正则表达式引擎将不会跟踪先前的位置,而只会放弃匹配。

    2.2K50

    简单了解SQL性能优化工具MySql Explain

    就是说mysql从第一个表中读取一行,在第二个表中找到匹配的一行,之后在找到第三个表,以此类推。 explain输出列包含如下信息: id 执行编号,标识select所属的行。...key_len 显示mysql在索引里使用的字节数 ref 显示了之前的表在key列记录的索引中查找值所用的列或常量 rows 为了找到所需的行而需要读取的行数,估算值,不精确。...使用唯一性索引或主键查找时会发生 (高效) const:当确定最多只会有一行匹配的时候,MySQL优化器会在查询前读取它而且只读取一次,因此非常快。...如果没有选择索引,键是NULL。要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。...ref ref列显示使用哪个列或常数与key一起从表中选择行。 rows rows列显示MySQL认为它执行查询时必须检查的行数。注意这是一个预估值。

    1.5K20

    MySQL EXPLAIN详解

    key_len 显示mysql在索引里使用的字节数 ref 显示了之前的表在key列记录的索引中查找值所用的列或常量 rows 为了找到所需的行而需要读取的行数,估算值,不精确。...该值可能为NULL,如果这一行用来说明的是其他行的联合结果。...使用唯一性索引或主键查找时会发生 (高效) const 当确定最多只会有一行匹配的时候,MySQL优化器会在查询前读取它而且只读取一次,因此非常快。...如果没有选择索引,键是NULL。要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。...ref ref列显示使用哪个列或常数与key一起从表中选择行。 rows rows列显示MySQL认为它执行查询时必须检查的行数。注意这是一个预估值。

    1.3K90
    领券