首页 > 数据库 >MySQL面试题(三)

MySQL面试题(三)

时间:2022-10-07 13:33:55浏览次数:60  
标签:语句 面试题 数据库 事务 索引 MySQL 优化 连接

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

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

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

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

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

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

MySQL面试题(三)_MySQL

29、实践中如何优化 MySQL

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

1 、  SQL 语句 及索 引的 优化

2、数据库表结构的优化

3、系 统配 置的 优化

4、硬件的优化

MySQL面试题(三)_sql_02

30、优化数据库的方法

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

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

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

4、事务处理

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

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

7、建立索引

8、优 化查 询语 句

MySQL面试题(三)_数据库_03

MySQL面试题(三)_MySQL_04

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

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

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

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

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

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

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

MySQL面试题(三)_MySQL_05

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

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

事务特性:

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

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

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

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

或者 这样理解:

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

MySQL面试题(三)_数据库_06

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,优化,连接
From: https://blog.51cto.com/u_15553407/5734434

相关文章

  • python+request+pymysql+pytest数据驱动
    一.pymysql简单使用1.安装mysql下载地址:https://www.mysql.com/,安装教程这里不做介绍了,网上一大推。2.安装pymysql库在Terminal终端输入:pipinstallpymysql3.pymysql......
  • MySQL基础--事务--2022年10月7日
    第一节  事务简介1、什么是事务2、注意:默认MySQL的事务是自动提交的,也就是说,当执行完一条DML语句时,MaSQL会立即隐式的提交事务。第二节  事务......
  • MySQL--多表查询--2022年9月30日
    第一节  多表关系1、一对多2、多对多3、一对一第二节  多表查询概述1、笛卡尔积:select*fromA,B;......
  • MySql基础知识总结
    Mysql基础知识总结一、Mysql的安装与卸载(Windows环境)二、Mysql的连接方式三、Mysql的基本常用语句四、Java连接Mysql技术Java连接Mysql的步骤在Java项目中写......
  • redis 面试题汇总
    什么是RedisRedis是一个开源的使用ANSIC语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API的非关系型数据库......
  • 一. mysql数据库优化总结
    四大优化方面:    减少数据访问减少磁盘访问1.建表、表字段2.索引 2.1为什么要用索引 2.2 索引分类 2.3 什么时候用索......
  • CentOS 7.9 安装 MySQL 5.7.35
    CentOS7.9安装MySQL5.7.351下载地址:https://downloads.mysql.com/archives/community/2mysql5.7.35安装包上传到linux服务器使用Xftp或者wget在服务器上下载......
  • Java 面试题 10 - 海量数据处理算法
    大数据处理中的分治思想哈希映射:如果数据太大,不能全部放入内存中,就可以利用映射函数将每条数据映射到一个小文件中,例如%1000可以将大文件映射成1000个小文件。相同的......
  • Java 面试题 11 - 分布式系统常见问题
    分布式ID的实现分布式ID需要满足哪些需求?基本需求:全局唯一高性能:生成速度快,对本地资源消耗小。高可用:生成分布式ID的服务要保证高可用性。方便易用:使用方便......
  • Java 面试题 09 - 计算机网络
    TCP&UDPTCP和UDP的区别有什么?TCP面向连接,UDP无连接。TCP提供可靠的传输,在传递数据之前,需要通过三次握手建立连接,在传递数据时,有确认、窗口、重传、拥塞机......