网络数据库后端面试题

接着上期

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连接就建立了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/22187.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

未来以来!鸿蒙生态爆发式增长,程序员新出路火速Get。

鸿蒙生态取得爆发式增长&#xff01; 鸿蒙生态建设速度突飞猛进&#xff0c;不仅有超4000款应用加速开发&#xff0c;众多头部SDK伙伴也在积极加入&#xff0c;为开发者提供构建鸿蒙原生应用所需的多项能力。近期&#xff0c;友盟移动统计SDK、神策数据SDK、阿里云日志服务SDK…

【Vue】v-bind对样式控制的增强-操作class

文章目录 一、语法二、示例代码三、京东秒杀-tab栏切换导航高亮四、v-bind对有样式控制的增强-操作style五、进度条案例 为了方便开发者进行样式控制&#xff0c; Vue 扩展了 v-bind 的语法&#xff0c;可以针对 class 类名 和 style 行内样式 进行控制 。 一、语法 语法 &l…

Latex中标注通讯作者

** 直接使用脚注&#xff0c;不用添加宏包 多个同地址的并列&#xff0c;建议加点空格&#xff0c;好看一些 ** \title{xxxxxxxxxxxxxxxxxxx}\author{xxxxxxxxxxxxxxxxxxx\footnote{Corresponding author} ,bbbbbbbbbbbbbbbbbbb}\address{xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx…

免费,Scratch蓝桥杯比赛历年真题--第15届蓝桥杯STEMA真题-2024年3月份(含答案解析和代码)

第15届蓝桥杯STEMA真题-2024年3月份 一、单选题 答案&#xff1a;D 解析&#xff1a;y坐标正值表示上&#xff0c;负值表示下&#xff0c;故答案为D。 答案&#xff1a;C 解析&#xff1a;18<25为真&#xff0c;或关系表示一真即为真&#xff0c;故答案为C。 答案&#xff…

Android设备获取OAID调研和实现

什么是OAID、AAID、VAID OAID OAID是"Android ID"&#xff08;安卓ID&#xff09;的一种替代方案&#xff0c;其全称为"Open Anonymous Identifier"&#xff08;开放匿名标识符&#xff09;。 因传统的移动终端设备标识如国际移动设备识别码&#xff08;…

冯喜运:6.5黄金原油今日行情趋势分析及操作策略

【黄金消息面分析】&#xff1a;在全球经济的波动中&#xff0c;美元和黄金市场的表现一直是投资者关注的焦点。最近&#xff0c;市场情绪和经济数据的波动对这两个市场产生了显著的影响。周二欧市早盘&#xff0c;现货黄金价格出现短线回调&#xff0c;金价跌破2340美元/盎司&…

数组中的第K个最大元素 ---- 分治-快排

题目链接 题目: 分析: 这道题很明显是一个top-K问题, 我们很容易想到用堆排序来解决, 堆排序的时间复杂度是O(N*logN), 不符合题意, 所以我们可以用另一种方法:快速选择算法, 他的时间复杂度为O(N)快速选择算法, 其实是基于快排, 进行修改而成, 我们还是使用将"将数组分…

Mode Solver ------- Mesh size 对仿真结果的影响

Mesh size 对仿真结果的影响 引言正文引言 在 FDE Solver ------ Straight Si waveguide simulation 硅直波导仿真(完美版) 一文中我们介绍了硅直波导的仿真。在 DE Solver ------ Simulation mesh settings 仿真网格设定(完美版) 一文中我们介绍如何设定仿真网格,在 Lum…

【Godot4自学手册】第四十一节背包系统(一)UI设置

各位同学&#xff0c;好久没有更新笔记了&#xff0c;今天开始&#xff0c;我准备自学背包系统。今天先学习下UI界面设置。 一、新建场景和结点 1.新建Node2D场景&#xff0c;命名为Inventory&#xff0c;保存到Scenes目录下&#xff0c;inventory.tscn。 2.新建TextureRect子…

kivy.garden.matplotlib

matplotlib 是什么 # pip install matplotlib2.2.2 from kivy.garden.matplotlib.backend_kivyagg import FigureCanvasKivyAgg FigureCanvasKivyAgg class FigureCanvasKivyAgg(FigureCanvasKivy, FigureCanvasAgg):FigureCanvasKivyAgg class. See module documentation f…

力扣题解 >>> 二叉树

验证二叉搜索树 递归判断数组是否升序 var isValidBST function(root) {// 搜索二叉树中序遍历之后的结果数组一定是升序if(!root){return true;}let result [];var dg function(node){if(node){dg(node.left);result.push(node.val);dg(node.right);}}dg(root);for(let i…

国联易安:网络反不正当竞争,要防患于未然

据市场监管总局官网消息&#xff0c;为预防和制止网络不正当竞争&#xff0c;维护公平竞争的市场秩序&#xff0c;鼓励创新&#xff0c;保护经营者和消费者的合法权益&#xff0c;促进数字经济规范健康持续发展&#xff0c;市场监管总局近日发布《网络反不正当竞争暂行规定》&a…

微信小程序-WXS脚本

一、概述 1.WXS WXS(WeiXin Script)是小程序独有的一套脚本语言&#xff0c;结合 WXML&#xff0c;可以构建出页面的结构。 2.wxs 的应用场景 wxml中无法调用在页面的.js 中定义的函数&#xff0c;但是&#xff0c;wxml 中可以调用 wxs 中定义的函数。因此&#xff0c;小程序…

Jupyter 各种主题

安装和更新主题 # 安装jupyter主题 pip install jupyterthemes # 加载可用主题列表 jt -l可用主题列表 Available Themes:chesterishgrade3gruvboxdgruvboxlmonokaioceans16onedorksolarizeddsolarizedl# 选择你想要的主题 jt -t <name of the theme> # 如 jt -t che…

软件测试总结基础

软件测试总结基础 1. 何为软件测试 定义&#xff1a;使用技术手段验证软件是否满足需求 目的&#xff1a;减少bug&#xff0c;保证质量 2. 软件测试分类 阶段划分 单元测试&#xff0c;针对源代码进行测试集成测试&#xff0c;针对接口进行测试系统测试&#xff0c;针对功能…

Web 网页性能优化

Web 网页性能及性能优化 一、Web 性能 Web 性能是 Web 开发的一个重要方面&#xff0c;侧重于网页加载速度以及对用户输入的响应速度 通过优化网站来改善性能&#xff0c;可以在为用户提供更好的体验 网页性能既广泛又非常深入 1. 为什么性能这么重要&#xff1f; 1. 性能…

人工智能学习笔记(1):了解sklearn

sklearn 简介 Sklearn是一个基于Python语言的开源机器学习库。全称Scikit-Learn&#xff0c;是建立在诸如NumPy、SciPy和matplotlib等其他Python库之上&#xff0c;为用户提供了一系列高质量的机器学习算法&#xff0c;其典型特点有&#xff1a; 简单有效的工具进行预测数据分…

YoloV8改进策略:Neck篇|自研Neck层融合模型|深度特征与浅层特征融合,涨点明显|附结构图(独家原创)

摘要 本文介绍的独家原创的Neck层特征融合方法&#xff0c;将深度特征和浅层特征相融合&#xff0c;结合自研下采样模块和动态上采样模块&#xff0c;提供了一种高效的Neck层改进方式&#xff0c;不仅为他们提供了一个现成的解决方案&#xff0c;而且能够作为灵感启发&#xf…

SysTools MailXaminer 电子邮件取证工具,发现电子邮件中的秘密

天津鸿萌科贸发展有限公司是 SysTools 系列软件的授权代理商。 SysTools MailXaminer 电子邮件取证软件提供全功能解决方案&#xff0c;通过简化的操作&#xff0c;从电子邮件客户端、网络邮箱服务器、磁盘镜像、Skype 通讯工具中解密并搜索证据&#xff0c;支持单人取证模式和…

代码随想录训练营Day 49|力扣139.单词拆分、关于多重背包,你该了解这些!、背包问题总结篇!

1.单词拆分 视频讲解&#xff1a;动态规划之完全背包&#xff0c;你的背包如何装满&#xff1f;| LeetCode&#xff1a;139.单词拆分_哔哩哔哩_bilibili 代码随想录 代码&#xff1a; class Solution { public:bool wordBreak(string s, vector<string>& wordDict) …