网络数据库后端面试题

接着上期

8,索引是怎么提高查询效率的,是不是多越好 

索引是数据库中用来提高查询效率的技术,类似目录。如果不使用索引,数据会零散的保存在磁盘中,查询数据需要挨个遍历每一个磁盘块,直到找到数据,使用索引后会将磁盘块以树桩结构保存,查询数据时会大大降低磁盘块的访问数量,从而提高查询效率。

MYsql中的存储索引用的一般都是B+数

MYsql中索引用B+树的好处主要是降低树高度查询效率,多路设计保障硬盘到内存的加载,叶子结点存储数据并且加了指针形成链表在范围查找时只需要定位首尾就可以取出所需要的数据。

MYsql中索引的优点和缺点是什么

优点

所有的mysql列类型(字段类型)都可以被索引,也就是给任意字段位置设置索引大大加快数据的查询速度

缺点:

创建索引和维护索引要消耗时间,并且随着数据量的增加所消耗的时间也会增加

9, 数据库事务的四个特性含义

原子性:要么全部执行,要么不执行

一致性:事务开始前和结束后对数据的完整性不会破坏

隔离性:允许多个并发事务同时对数据的读写,防止多个并发执行引起的不一致

持久性: 事务结束后,对数据的修改是永久的

10 , 数据库的三范式

第一范式: 一个字段只包含一个信息(原子性),避免数据的重复

第二范式: 每一行的数据只能与其中一列相关,即一行数据只能做一件事

第三范式:数据不能存在传递关系,即每个属性都跟主键有直接关系而不是间接关系

11, 数据库优化思路

SQL 语句优化

一,尽量避免在where子句中只用!= 或<>操作符,否则将引擎放弃使用索引而进行全表的扫描。

二,尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表的扫描。

三, 很多时候用exists替代in是一个好的选择

四, 用where子句替换having子句 因为having只会在检索出所有记录之后才对结果集进行过滤

12, 什么是redis持久化?Redis有哪几种持久化?优缺点是什么?

持久化就是把内存的数据写到磁盘中,防止服务宕机了内存数据丢失

redis提供了两种持久化方式RDB和AOF

RDB就是在指定的时间间隔内将内存的数据集快照写入磁盘,它恢复时将快照文件直接读到内存里。RDB持久化就是把当前Redis中全部数据生成快照保存在硬盘上,RDB持久化可以手动触发,也可以自动触发。

AOF持久化是把命令追加写入日志,需要恢复数据时重新执行AOF文件中的命令就可以了。AOF解决了数据持久化的实时性,也就是目前主流的redis持久化方式。

一AOF文件比RDB更新频率更高,优先使用AOF还原数据

二AOF比RDB更安全也更大

三RDB性能比AOF好

四如果两个都配了优先加载AOF

13, 什么是http协议

HTTP协议是超文本传输协议,用于从万维网服务器传输超文本到本地浏览器的传输协议。HTTP是一个基于TCP/IP通信协议来传输数据

14,http协议的报文构成

请求报文包含三个部分

请求行:包含请求方法,URL, HTTP版本信息

请求头:请求的相关配置

请求体:post参数的位置

15, http,https协议有什么区别?

http协议超文本传输协议,被用于在web浏览器和网站服务器之间传递信息,以明文方式发送内容,不对数据加密,很容易被黑客入侵,安全性不高。

为了传输的安全,在https在http的基础上加入了SSL协议,SSL协议依靠ca证书来验证服务器的身份,为了浏览器和服务器之间的通信加密,https的加密机制是一种共享密钥加密和公开密钥加密并用的混合加密机制。

HTTP协议运行在tcp之上,明文传输,客户端与服务器都无法验证对方的身份;HTTPS是身披SSL外壳的HTTP 运行在SSL之上,SSL运行在TCP之上,是添加了加密和认证机制的HTTP。二者之间存在以下不同:

一,端口不同:http与HTTPS使用不同的连接方式,用的端口也不一样,前者是80端口,后者是443端口;

二, 资源消耗:和http相比,HTTPS通信会由于加减密处理消耗跟多的cpu和内存资源

三, 开销: HTTPS通信需要证书,而3证书一般需要向机构购买

16 http响应常见码都有哪些?

100~199:表示成功接受请求,要客户端继续提交下一次才能完成整个处理过程

200~299:表示成果接受请求并以完成整个的处理过程,常用200

300~399:为完成请求,客户需要进一步细化需求:例如:请求资源已经移动到了一个新的地址

常用的302重定向 304拿缓存

400~499: 客户端的请求又错误,包含语法错误或者不能正确执行,常用404(请求资源在web服务器中没有) 403(服务器拒绝访问,权限不够)

500~599: 服务器端出现错误

200 正常, 表示一切正常,返回的是正常的请求

302/307: 临时重定向,指出请求文档已经被临时移动到别的地方,此文档的新url在location响应中给出

304: 未修改,表示客户机缓存的版本是最新的,客户机应该继续使用它

403: 禁止,服务器理解客户机的请求,但是拒绝他,通常用于服务器上的文件或目录的权限设置所致

404:找不到,服务器上不存在客户机所请求的资源 

500: 服务器内部错误,服务器端的代码程序发生错误

17,说一下tcp三次握手

建立tcp连接需要三次握手,三次握手:首先, client端发送连接请求报文,server端接受连接后回复ack报文,并为这次连接分配资源。client端接收ack报文后也向server端发送ack报文,并分配资源,这样tcp连接就建立了

相关推荐

  1. 网络数据库端面试题

    2024-06-12 14:58:02       30 阅读
  2. 端面试题——网络

    2024-06-12 14:58:02       47 阅读
  3. 端面试题数据处理

    2024-06-12 14:58:02       43 阅读
  4. 端面试题html

    2024-06-12 14:58:02       57 阅读
  5. 端面试题css

    2024-06-12 14:58:02       52 阅读
  6. 端面试题-webpack

    2024-06-12 14:58:02       59 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-12 14:58:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-12 14:58:02       101 阅读
  3. 在Django里面运行非项目文件

    2024-06-12 14:58:02       82 阅读
  4. Python语言-面向对象

    2024-06-12 14:58:02       91 阅读

热门阅读

  1. c++:回顾(一)

    2024-06-12 14:58:02       34 阅读
  2. 杂项——编码器控制小车走固定距离(stm32)

    2024-06-12 14:58:02       36 阅读
  3. 2833.距离原点最远的点

    2024-06-12 14:58:02       34 阅读
  4. 亚马逊云服务器价格贵不贵?

    2024-06-12 14:58:02       31 阅读
  5. 设计模式之建造者模式

    2024-06-12 14:58:02       31 阅读
  6. 音视频开发26 FFmpeg 时间问题整理

    2024-06-12 14:58:02       33 阅读
  7. 05 Hadoop简单使用

    2024-06-12 14:58:02       25 阅读
  8. k8s redis 单节点部署

    2024-06-12 14:58:02       30 阅读