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

2020年MySQL数据库面试题总结(50道题含答案解析)

6、主键和候选键有什么区别? 表格的每一行都由主键唯一标识,一个表只有一个主键。 主键也是候选键。按照惯例,候选键可以被指定为主键,并且可以用于任何外键引用。...外连接  其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接 也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL 来填充。...右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL 目前还不支持全外连接。...主键——用来保证数据完整性 外键——用来和其他表建立联系用的 索引——是提高查询排序的速度 个数: 主键—— 主键只能有一个 外键—— 一个表可以有多个外键 索引—— 一个表可以有多个唯一索引 49、你可以用什么来确保表格里的字段只接受特定范围里的值

4K20

MySQL 给你问懵了?50 道 MySQL 高频面试题详解来了

6、主键和候选键有什么区别? 表格的每一行都由主键唯一标识,一个表只有一个主键。 主键也是候选键。按照惯例,候选键可以被指定为主键,并且可以用于任何外键引用。...外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接,也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL 来填充。...右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL 目前还不支持全外连接。...主键——用来保证数据完整性 外键——用来和其他表建立联系用的 索引——是提高查询排序的速度 个数: 主键—— 主键只能有一个 外键—— 一个表可以有多个外键 索引—— 一个表可以有多个唯一索引 49

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

    MySQL 常见的面试题及其答案

    不可变性:主键的值不能更改。 5、什么是外键? 外键是一种用于建立两个表之间关联的字段。外键通常指向另一个表中的主键。 6、什么是索引? 索引是一种用于加速查询的数据结构。...MySQL中实现外键约束的方法: 在创建表时,使用FOREIGN KEY约束指定外键,指向另一个表的主键。 外键约束可以在CREATE TABLE或ALTER TABLE语句中指定。...当使用外键约束时,必须使用InnoDB存储引擎。 外键约束可以保证数据的完整性,避免数据丢失或不一致。 如果试图删除具有关联记录的主键,则会拒绝删除操作。...如果试图插入与另一个表中不存在的外键,则会拒绝插入操作。 可以使用CASCADE选项来自动删除或更新具有关联记录的外键记录。 24、什么是MySQL存储引擎?MySQL支持哪些存储引擎?...MySQL中还有其他类型的锁,例如行级锁定和表级锁定,这些锁可以更细粒度地控制数据访问

    7.1K31

    2022 最新 MySQL 面试题

    6、主键和候选键有什么区别? 表格的每一行都由主键唯一标识 ,一个表只有一个主键。 主键也是候选键。 按照惯例, 候选键可以被指定为主键, 并且可以用于任何外键 引用。...外连接 其结果集中不仅包含符合连接条件的行 ,而且还会包括左表 、右表或两个 表中 的所有数据行, 这三种情况依次称之为左外连接, 右外连接, 和全外连接。...左外连接, 也称左连接, 左表为主表, 左表中的所有记录都会出现在结果集中, 对于那些在右表中并没有匹配的记录, 仍然要显示, 右边对应的那些字段值以 NULL 来填充 。...右外连接 ,也称右连接,右表为主表 ,右表中的所有记录都会出现 在结果集中。 左连接和右连接可以互换, MySQL 目前还不支持全外连接。...作用: 主键 – 用来保证数据完整性 外键 – 用来和其他表建立联系用的 索引 – 是提高查询排序的速度 个数: 主键 – 主键只能有一个 外键 – 一个表可以有多个外键 索引 – 一个表可以有多个唯一索引

    10210

    MySQL经典52题

    6.主键和候选键有什么区别?表格的每一行都由主键唯一标识,一个表只有一个主键。主键也是候选键。按照惯例,候选键可以被指定为主键,并且可以用于任何外键引用。7.myisamchk是用来做什么的?...外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接 也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL来填充。...右外连接 也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL目前还不支持全外连接。...:用来和其他表建立联系用的索引:是提高查询排序的速度3、从个数上区分主键:主键只能有一个外键:一个表可以有多个外键索引:一个表可以有多个唯一索引52.SQL语句优化方法Where子句中:where表之间的连接必须写在其他

    11410

    SQL重要知识点梳理!

    外键(foreign key):如果关系模式R中属性K是其它模式的主键,那么k在模式R中称为外键。...左外连接: 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行。 右外连接: 包含右边表的全部行(不管左边的表中是否存在与它们匹配的行),以及左边表中全部匹配的行。...全外连接: 包含左、右两个表的全部行,不管另外一边的表中是否存在与它们匹配的行。...在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法。这种数据结构,就是索引。...通过保存数据在某个时间点的快照来实现该机制,其在每行记录后面保存两个隐藏的列,分别保存这个行的创建版本号和删除版本号,然后Innodb的MVCC使用到的快照存储在Undo日志中,该日志通过回滚指针把一个数据行所有快照连接起来

    82020

    Mysql面试题

    主键和候选键有什么区别? 表格的每一行都由主键唯一标识,一个表只有一个主键。 主键也是候选键。按照惯例,候选键可以被指定为主键,并且可以用于任何外键引用。 6. Mysql 单表的有最大数量限制吗?...外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接 也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL来填充。...定义: 主键–唯一标识一条记录,不能有重复的,不允许为空 外键–表的外键是另一表的主键, 外键可以有重复的, 可以是空值 索引–该字段没有重复值,但可以有一个空值 作用: 主键–用来保证数据完整性 外键...–用来和其他表建立联系用的 索引–是提高查询排序的速度 个数: 主键–主键只能有一个 外键–一个表可以有多个外键 索引–一个表可以有多个唯一索引

    1.2K51

    SQL岗位30个面试题,SQL面试问题及答案「建议收藏」

    表是在具有列和行的模型中设计的数据集合。在表中,指定了列数称为字段,但未定义行数称为记录。 什么是数据库? 数据库是有序形式的一组信息,用于访问、存储和检索数据。 DBMS的类型是什么?...Join用于从相关的行和列中检索数据。它在两个或多个表之间工作,并且它从两个表返回至少一个匹配。...· ForeignKey(外键)——在一个表中定义主键并在另一个表中定义字段的键被标识为外键。...并且在非集群索引的情况下,该表可以具有多个索引,为表创建一个对象,该表是搜索后指向表的一个点。 什么是Trigger(触发器)?...Atomicity(原子性)——在连接两个或多个单独数据的事务中,要么所有部分都已提交,要么都没有。

    4.5K31

    SQL Server 数据库学习「建议收藏」

    主键:建立一列或多列的组合以唯一标识表中的每一行,主键可以保证实体的完整性,一个表只能有一个主键。 (3)保存新建的表,并给起一个名字。 (4)修改数据表。选择要修改的数据表,右击——设计。...(5)创建检查约束,检查约束可以把输入的数据限制在指定范围。 设计——选择一列——右击 check约束 (6)创建外键:外键是建立两个表数据之间连接的一列或多列。...通过将保存表中主键值的一列或多列添加到另一个表中,可以创建两个表之间的连接。这个列为第二个表的外键。...(1)简单基本连接 (2)内连接 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。 如: (3)外连接 外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。...左外链接: 右外连接: 完全连接:返回两个表中所有匹配行和不匹配行 3.3.2 insert 插入语句 3.3.3 update语句修改指定的数据 3.3.4 delete 语句删除指定数据

    1.6K10

    DBA-MySql面试问题及答案-下

    3.页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。 15.主键和候选键有什么区别? 表格的每一行都由主键唯一标识,一个表只有一个主键。 主键也是候选键。...对于一些特殊的数据类型,不宜建立索引,比如文本字段(text)等 47.解释MySQL外连接、内连接与自连接的区别 先说什么是交叉连接: 交叉连接又叫笛卡尔积,它是指不使用任何条件,直接将一个表的所有记录和另一个表中的所有记录一一匹配...外连接 其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中 的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。...左外连接,也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以NULL来填充。...右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。左连接和右连接可以互换,MySQL目前还不支持全外连接。

    24620

    30个精选SQL面试问题Q&A集锦

    表是在具有列和行的模型中设计的数据集合。在表中,指定了列数称为字段,但未定义行数称为记录。 3. 什么是数据库? 数据库是有序形式的一组信息,用于访问、存储和检索数据。 4. DBMS的类型是什么?...什么是SQL中的Joins(连接)? Join用于从相关的行和列中检索数据。它在两个或多个表之间工作,并且它从两个表返回至少一个匹配。...ForeignKey(外键)——在一个表中定义主键并在另一个表中定义字段的键被标识为外键。...并且在非集群索引的情况下,该表可以具有多个索引,为表创建一个对象,该表是搜索后指向表的一个点。 18. 什么是Trigger(触发器)?...Atomicity(原子性)——在连接两个或多个单独数据的事务中,要么所有部分都已提交,要么都没有。

    1.5K10

    MySQL 面试题

    这样,它避免了”不可重读读“,但仍然可能出现”幻读“,即在同一个事务内,两个相等的查询可能因为其他事务插入新行而返回不同行数的结果。...外键关系: 只有主键才能被其他表用作外键建立引用约束。 候选键除非被选作主键,否则不会用于建立外键关系。 简而言之,候选键是拥有唯一识别能力的键的总成,其中一个被选作主键用于唯一确定表中的每一行。...什么叫外连接 外连接(Outer Join)是 SQL 中的一种连接查询,用来从两个表中返回匹配的行,以及在另一个表中没有匹配的行。...全外连接(Full Outer Join): 返回左表和右表中的所有行。 当左表中某行没有匹配右表时,或者右表中某行没有匹配左表时,结果集中对于缺失的匹配会用 NULL 填充。...什么叫内连接 内连接(Inner Join)是数据库 SQL 语言中最常见的类型的连接,它用于返回两个或多个表中符合连接条件的记录。

    15911

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    一个表可以具有多个非聚集索引。 它不会改变其排序方式,但是会在一个表内创建一个单独的对象,该对象在搜索后指向原始表行。 20.什么是SQL视图? 视图就像逻辑上存储在数据库中的表的子集。...联接的类型如下: 内部联接 左联接 正确加入 外连接 35.内部联接和外部联接之间有什么区别? 内部联接:当正在比较的两个(或多个)表之间至少有一些匹配数据时,内部联接将返回行。...SQL中可用的约束有哪些? SQL中的一些约束包括–主键,外键,唯一键,SQL非空,默认,检查和索引约束。 38.什么是唯一约束? 使用唯一约束来确保字段/列中没有重复值。 39.什么是主键?...简短的答案是“否”,一个表不允许包含多个主键, 但是它允许一个包含两个或更多列的复合主键。 41.什么是复合 主键? 复合主键是在表中的多个列(多个字段的组合)上创建的主键。 42.什么是外键?...自联接是表与自身联接的联接,特别是当表具有引用其自己的主键的外键时。 73.什么是交叉加入?

    27.1K20

    C# .NET面试系列十:数据库概念知识

    在关系型数据库中,JOIN 是用于连接两个或多个表的操作,以便从这些表中获取相关联的数据。以下是几种不同类型的 JOIN:1、INNER JOININNER JOIN 返回两个表中满足连接条件的行。...在关系型数据库中,使用外键来建立这些关系,确保表之间的连接正确且具备数据完整性。9. 什么是主键?主键(Primary Key)是数据库表中的一列或一组列,其目的是唯一标识表中的每一行数据。...外键具有以下特性:1、关联性外键用于建立表之间的关联,通过在一个表中存储对另一个表的引用,实现了表与表之间的连接。...CASCADE 操作会在引用表的行发生变化时,自动更新或删除与之关联的行。这有助于确保关联表和引用表之间的数据保持一致。在创建外键时,引用表的列必须具有唯一性,通常是主键或唯一键。...外键通常连接到另一个表的主键。

    1.1K10

    115道MySQL面试题(含答案),从简单到深入!

    InnoDB支持事务处理,行级锁定和外键,适用于需要高并发和事务处理的场景。MyISAM不支持事务和行级锁定,但读取速度快,适用于查询密集型的场景。3. 解释MySQL中的JOIN操作。...类型包括INNER JOIN(只返回两表匹配的行)、LEFT JOIN(返回左表的所有行及右表匹配的行)、RIGHT JOIN(返回右表的所有行及左表匹配的行)等。4. 如何优化MySQL查询?...解释MySQL中的主键与唯一键的区别。主键(Primary Key)是表中用于唯一标识每条记录的列或列的组合。一个表只能有一个主键,且主键列的值必须是唯一的,不允许为NULL。...常见的归一化形式包括第一范式(1NF)、第二范式(2NF)、第三范式(3NF)和博耶-科得范式(BCNF)。10. 解释MySQL中的外键。外键是一种数据库约束,用于建立两个表之间的关系。...在一个表中的外键会指向另一个表的主键。外键的主要作用是维护跨表的数据完整性,确保参照完整性。11. 解释MySQL中的事务隔离级别以及它们如何影响并发。

    2K10

    JavaWeb06-MySQL深入学习这些就够了!

    外键约束特性如下: 外键必须是另一表主键的值; 外键可以重复; 外键可以为null; 一张表中可以有多个外键。 表之间关联关系 1....开发中,一般新建一张中间表,这个中间表只放双方的id,然后就拆成了两个一对多的关系.然后一般将两个id设成联合主键,然后对每个id添加外键约束.如下图....: alter table 当前表 add [constraint] foreign key (需要设为外键的字段) references 指向表(指向表的主键字段) b.两张表合二为一,例如,在person...交叉连接(cross join) 又称笛卡尔连接(cartesian join)或叉乘(Product),它是所有类型的内连接的基础。把表视为行记录的集合,交叉连接即返回这两个集合的笛卡尔积。...; 上面这条sql我们使用的是左外连接,它的意思就是说以user表为准,保留user表中所有数据,右表orders中没有关联的数据,那么就以null关联显示出来, 执行的结果如下: 2.

    1.4K60

    数据库面试题汇总

    FOREIGN KEY: 用于预防破坏表之间连接的动作,也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。 CHECK: 用于控制字段的值范围。...场景使用 不再需要一张表的时候,用drop 想删除部分数据行时候,用delete,并且带上where子句 保留表而删除所有数据的时候用truncate 超健、候选键、主键、外键 超健 在关系中能唯一标识元组的属性集称为关系模式的超键...主键 数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。一个数据列只能有一个主键,且主键的取值不能缺失,即不能为空值(Null)。 外键 在一个表中存在的另一个表的主键称此表的外键。...视图的使用场景 只暴露部分字段给访问者,所以就建一个虚表,就是视图 查询的数据来源于不同的表,而查询者希望以统一的方式查询,这样也可以建立一个视图,把多个表查询结果联合起来,查询者只需要直接从视图中获取数据...的方式来进行锁定 实现方式:使用version版本或者时间戳 表的连接方式 类型 内连接 自连接 外连接 交叉连接 内连接 只有两个元素表相匹配的才能在结果集中显示 外连接 左外连接:左边为驱动表,驱动表的数据全部显示

    1.9K21

    SqlAlchemy 2.0 中文文档(五十四)

    中,所有表实际上都应该具有某种主键,否则你可能需要实际更新或删除特定行)。...几乎在所有情况下,表都具有所谓的 候选键,这是一列或一系列列,唯一标识一行。如果表确实没有这个,且具有实际完全重复的行,则该表不符合第一范式,无法进行映射。...我已经针对外连接创建了映射,但是虽然查询返回行,但没有返回对象。为什么? 由外连接返回的行可能包含主键的部分 NULL,因为主键是两个表的组合。Query对象忽略不具有可接受主键的传入行。...,以协调设置具有多对一关系的外键属性。...我已经创建了一个针对 Outer Join 的映射,虽然查询返回了行,但没有返回对象。为什么? 外部连接返回的行可能会对主键的某部分包含 NULL,因为主键是两个表的组合。

    36010

    sql基础之多表查询?嵌套查询?

    但在我们真正开始连接表之前,让我们先了解一下主键和外键。 主键 主键是表中的一列(有时是一组列),是每行的唯一标识符。...数据库通常有一个名为 id 的列(customerID、emailID、EmployeeID)作为每个表的主键。 外键 外键是表中的列,指定到另一个表中主键的链接。...回到 JOINS,让我们看看下面的数据集以了解它们的工作原理: 例如,您想要一个包含所有用户和事件表数据的表 为此,您将使用外连接。...如果可能,左连接会组合公共维度上的列(前 N 列),返回第一个表中的所有行以及连续表中的匹配行。当没有匹配时,连续表中的结果为 NULL。...右连接尽可能组合公共维度上的列(前 N 列),返回第二个/右表中的所有行以及第一个/左表中的匹配行。 举一个例子 多表查询是SQL查询中的一个重要环节,用于从两个或更多表中查询相关数据。

    60410

    MySQL基础这样学

    1.3、书写规则 数据库中,SQL 语句大小写不敏感. 如: select、SELECT.、SeleCt,为了提高可读性,一般关键字大写,其他小写。...主键自增长:AUTO_INCREMENT,从 1 开始,步长为 1。 外键约束:FOREIGN KEY,A表中的外键列. A表中的外键列的值必须参照于B表中的某一列(B表主 键)。...外键可以为NULL,且不一定是另一张的主键,但是必须具有唯一性,一般情况下会引用另一张表的主键。...设计从表可以有两种方案: 在t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束; 给t_card表的主键添加外键约束(相对t_user表),即t_card表的主键也是外键。...例如再创建一张表t_stu_tea表,给出两个外键,一个相对t_stu表的外键,另一个相对t_teacher表的外键。

    2.2K20
    领券