MySQL面试题(三)

27、索引的底层实现原理和优化

B+树, 经过优化的B+树主 要是在所有的叶子结点中增加了指向下一个叶子节点的指针,  因此InnoDB 建 议 为大部分表使用默认自增的主键作为主索引。

28、什么情况下设置了索引但无法使用

1、  以 “ % ” 开 头 的 LIKE 语 句 ,  模 糊 匹 配

2 、  OR 语 句 前 后 没 有 同 时 使 用 索 引

3 、数 据 类 型 出 现 隐式转化(如 varchar 不 加 单 引 号 的 话 可 能 会 自 动 转 换 为 int 型 )

29、实践中如何优化 MySQL

最好是按照以下顺序优化:

1 、  SQL 语句 及索 引的 优化

2、数据库表结构的优化

3、系 统配 置的 优化

4、硬件的优化

30、优化数据库的方法

1、选取 最适 用的 字段 属性 ,尽可 能减 少定 义字 段宽 度 ,尽量把字段设置NOTNULL,例如’省份 ’ 、   ’ 性别 ’最好 适用ENUM

2、使用连接(JOIN)来代 替子 查询

3、适用联合(UNION)来代 替手 动创 建的 临时 表

4、事务处理

5、锁 定表 、优 化事 务处 理

6、适用外键, 优化锁定表

7、建立索引

8、优 化查 询语 句

31、简单描述 MySQL 中,索引,主键,唯一索引,联合索引的区别,对数据库的性能有什么影响(从读写两方面)

索引是一种特殊的文件(InnoDB 数据表上的索引是表空间的一个组成部分),   它们包含着对数据表里所有记录的引用指针。

普通 索引(由关 键字 KEY 或INDEX 定义的索引)的唯 一任 务是 加快 对数 据的 访问 速 度。

普通索引允许被索引的数据列包含重复的值。 如果能确定某 个数据列将只包含彼 此各 不相同的值, 在为这个数据列创建索引的时候就应该用关键字UNIQUE 把它 定义为一个唯一索引。 也就是说,  唯一索引可以保证数据记录的唯一性。

主键, 是一种特殊的唯一索引, 在一张表 中只能定义一个主键索引, 主键用于唯 一标 识一条记录, 使用关键字 PRIMARY KEY  来创建。

索引可以覆盖多个数据列,如像INDEX(columnA, columnB)索引 ,这就 是联 合索 引。

索引可以极大的提高数据的查询速度, 但是会降低插入、删除、 更新表的速度, 因为在执行这些写 操作时, 还要操作索引文件。

32、数据库中的事务是什么?

事务 (transaction)  是 作为 一个 单元 的一 组有 序的 数据 库操 作。  如果 组中 的所 有操作都成功, 则认为事务成功,  即使只有一个操作失败, 事务也不成功。 如果所有操作完成, 事务则提交, 其修改将作用于所有其他数据库进程。如果一个操作失败, 则事务将回滚, 该事务所有操作的影响都将取消 。

事务特性:

1、原子性:  即不可分割性, 事务要么全部被执行, 要么就全部不被执行。

2 、  一致 性或 可串 性 。  事务 的执 行使 得数 据库 从一 种正 确状 态转 换成另一种正确状 态

3 、  隔离 性 。  在事 务正确提交之前, 不允许把该事务对数据的任何改变提供给任何 其他事务,

4 、  持久性。 事务正确提交后, 其结果将永久保存在数据库中, 即使在事务提交后 有了其他故障, 事务的处理结果也会得到保存。

或者 这样理解:

事务就是被绑定在一起作为 一个逻辑工作单元的SQL 语句分组, 如果任何一个语 句操作失败那么整个操作就被失败,  以后操作就会回滚到操作前状态, 或者是上 有个节点。为了确保要么执行, 要么不执行, 就可以使用事务。 要将有组语句作为事务考虑, 就需要通过ACID 测试 ,   即 原子 性,  一致 性,   隔离 性和 持久 性。

33、SQL 注入漏洞产生的原因?如何防止?

SQL 注入产生的原 因: 程序开发过程中不注意规范书写sql 语句和对特殊字符进   行过滤,导致客户端可以通过全局变量POST 和GET 提交一些sql 语句正常执行。

防止SQL 注入的方式:

开启配置文件中的magic_quotes_ gpc  和 magic_quotes_ runtime 设置

执行sql 语句时使用addslashes 进行sql 语句转换

Sql 语句书写尽量不要省略双引号和单引号。

过滤掉sql 语句中的一些关键词:  update 、   insert 、   delete 、   select 、     *  。

提高数据库表和字段的命名技巧, 对一些重要的字段根据程序的特点命名, 取不 易被猜到的。

 34、为表中得字段选择合适得数据类型

字段类型优先级:  整形 >date,time>enum,char>varchar>blob,text

优先考虑数字类型, 其次是日期或者二进制类型, 最后是字符串类型,  同级别得 数据类型, 应该优先选择占用空间小 的数据类型

35、存储时期

Datatime:以  YYYY - MM - DD HH:MM:SS  格式存储时期时间, 精确到秒, 占用8 个字 节得存储空间,  datatime 类型与时区无关

Timestamp:以时间戳格式存储,占用4 个字 节 ,范围 小 1970 - 1 - 1 到 2038 - 1 - 19, 显示依赖于所指定得时区, 默认在第一个列行的数据修改时可以自动得修改

timestamp 列得值

Date:  (生 日)   占用 得字 节数 比使 用字 符串 .datatime. int 储存要少, 使用date 只 需要3 个字 节,  存储 日期月份, 还可以利用日期时间函数进行日期间得计算

Time:存储 时间 部分 得数 据

注意 :不要 使用 字符 串类 型来 存储 日期 时间 数据 (通常 比字 符串 占用 得储 存空 间小 , 在进行查找过滤可以利用日期得函数)                                                                            
使用int 存储日期时间不如使用timestamp 类型

36、对于关系型数据库而言,索引是相当重要的概念,请回答有关索引的几个问题:

1、  索 引 的 目 的 是 什 么 ?

快 速访问数据表中的特定信息, 提高检索速度

创 建唯一性索引, 保证数据库表中每一行数据的唯一性。

加 速表和表之间的连接

使用分组和排序子句进行数据检索时, 可以显著减少查询中分组和排序的时间

2、 索引对数据库系统的负面影响是什么?

负面影响:

创建 索引和维护索引需要耗费时间, 这个时间随着数据量的增加而增加; 索引需 要占 用物理空间, 不光是表需要占用数据空间, 每个索引也需要占用物理空间; 当 对 表 进行增、 删、 改、  的时候索引也要动态维护, 这样就降低了数据的维护速 度 。

3、 为数据表建立索引的原则有哪些?

在 最频繁使用的、 用以缩小查询范围的字段上建立索引。在 频繁使用的、 需要排序的字段上建立索引

4、 什 么 情 况 下 不 宜 建 立 索 引 ?

对于查询中很少涉及的列或者重复值比较多的列, 不宜建立索引。

对于一些特殊的数据类型, 不宜建立索引,  比如文本字段(text)  等

37、解释 MySQL 外连接、内连接与自连接的区别

先说什么是交叉连接:  交叉 连接 又叫 笛卡 尔积 ,它是 指不 使用 任何 条件 ,直接 将一 个表的所有记录和另一个表中的所有记录一一匹配。

内连接 则是只有条件的交叉连接, 根据某个条件筛选出符合条件的记录 , 不符合条件的记录不会出现在结果集中,  即内连接只连接匹配的行。

外连接 其结果集中不仅包含符合连接条件的行, 而且还会包括左表、 右表或两个表中的所 有数据行, 这三种情况依次称之为左外连接, 右外连接, 和全外连接。

左外 连接, 也称左连接, 左表为主表, 左表中的所有记录都会出现在结果集中,  对于那些在右表中并没有匹配的记录, 仍然要显示, 右边对应的那些字段值以      NULL 来填充。右外连接,也称右连接,右表为主表,右表中的所有记录都会出现 在结果集中。 左连接和右连接可以互换,  MySQL 目前 还不支持全外连接。

 

#MySQL##面试题#
全部评论
这种都可以看到也可以提前了解到
点赞 回复 分享
发布于 2022-08-27 13:40 河南

相关推荐

咦哟,从去年八月份开始长跑,两处实习转正都失败了,风雨飘摇,终于拿到offer了更新一下面试记录:秋招:多部门反复面试然后挂掉然后复活,具体问了啥已经忘了,只是被反复煎炸,直至焦香😋春招:base北京抖音hr打来电话说再次复活,准备面试,gogogo北京抖音一面:六道笔试题:1.promise顺序2.定义域问题3.flat展开4.并发请求5.岛屿数量算法(力扣)深度,广度都写6.忘记了,好像也是算法,难度中等其他问题多是框架底层设计,实习项目重难点~~~秒过😇北京抖音二面:三道笔试题:(为什么只有三道是因为第三道没做出来,卡住了)1.中等难度算法(忘记啥题了,应该是个数组的)2.认识js的继承本质(手写继承模式,深入js的面相对象开发)3.手写vue的响应式(卡在了watch,导致挂掉)---后知后觉是我的注册副作用函数写得有问题,有点紧张了其他题目多是项目拷打,项目亮点,对实习项目的贡献~~~第二天,挂,but立马复活转战深圳客服当天约面深圳客服一面:六道笔试题,由于面过太多次字节,面试官叫我直接写,不用讲,快些写完😋,具体都是些继承,深拷贝(注意对数组对象分开处理,深层次对象,循环引用),加中等难度算法题~~~秒过深圳客服二面:口诉八股大战:大概囊括网络,浏览器渲染原理,动画优化,时间循环,任务队列等等(你能想到的简单八股通通拉出来鞭尸😋)算法题:笔试题6道:1:找出数组内重复的数,arr[0]-arr[n]内的数大小为[1-n],例如[1,2,2,3,3]返回[2,3],要求o(n),且不使用任何额外空间(做到了o(n),空间方面欠佳,给面试官说进入下一题,做不来了)2:原滋原味的继承(所以继承真滴很重要)3:力扣股票购买时机难度中等其他滴也忘记了,因为拿到offer后鼠鼠一下子就落地了,脑子自动过滤掉可能会攻击鼠鼠的记忆😷~~~秒过深圳客服三面:项目大战参与战斗的人员有:成员1:表单封装及其底层原理,使用成本的优化,声明式表单成员2:公司内部库生命周期管理成员3:第三方库和内部库冲突如何源码断点调试并打补丁解决成员4:埋点的艺术成员5:线上项目捷报频传如何查出内鬼成员6:大文件分片的风流趣事成员7:设计模式对对碰成员8:我构建hooks应对经理的新增的小需求的故事可能项目回答的比较流利,笔试题3道,都很简单,相信大家应该都可以手拿把掐😇~~~过过过无hr面后续煎熬等待几天直接hr打电话发offer了,希望大家也可以拿到自己心仪的offer
法力无边年:牛哇,你真是准备得充分,我对你没有嫉妒,都是实打实付出
查看19道真题和解析
点赞 评论 收藏
分享
评论
12
48
分享

创作者周榜

更多
牛客网
牛客企业服务