MySQL体系结构

我们先下图看看MySQL整体逻辑架构(MySQLrsquo;s Logical Architecture),MySQL会解析查询,并创建了一个内部数据结构(解析树)

1.mysql整体逻辑架构

我们先下图看看MySQL整体逻辑架构(MySQL’s Logical Architecture)

MySQL体系结构

图1

第一层,即最上一层,所包含的服务并不是MySQL所独有的技术。它们都是服务于C/S程序或者是这些程序所需要的 :连接处理,,身份验证,安全性等等。

第二层值得关注。这是MySQL的核心部分。通常叫做 SQL Layer。在 MySQL据库系统处理底层数据之前的所有工作都是在这一层完成的,包括权限判断, sql解析,行计划优化, query cache 的处理以及所有内置的函数(如日期,时间,数学运算,加密)等等。各个存储引擎提供的功能都集中在这一层,如存储过程,触发器,视 图等。

第三层包括了存储引擎。通常叫做StorEngine Layer ,也就是底层数据存取操作实现部分,由多种存储引擎共同组成。它们负责存储和获取所有存储在MySQL中的数据。就像Linux众多的文件系统 一样。每个存储引擎都有自己的优点和缺陷。服务器是通过存储引擎API来与它们交互的。这个接口隐藏 了各个存储引擎不同的地方。对于查询层尽可能的透明。这个API包含了很多底层的操作。如开始一个事 物,或者取出有特定主键的行。存储引擎不能解析SQL,互相之间也不能通信。仅仅是简单的响应服务器 的请求。

连接管理和安全

在服务器内部,每个client连接都有自己的线程。这个连接的查询都在一个单独的线程中执行。这些线程轮流运行在某一个CPU内核(多核CPU)或者CPU中。服务器缓存了线程,因此不需要为每个client连接单独创建和销毁线程 。

当clients(也就是应用程序)连接到了MySQL服务器。服务器需要对它进行认证(Authenticate)。认证是基于用户名,主机,以及密码。对于使用了SSL(安全套接字层)的连接,还使用了X.509证书。clients一连接上,服务器就验证它的权限 (如是否允许客户端可以查询world数据库下的Country表的数据)。

优化和执行

MySQL会解析查询,并创建了一个内部数据结构(解析树)。然后对其进行各种优化。这些优化包括了,查询语句的重写,读表的顺序,索引的选择等等。用户可以通过查询语句的关键词传递给优化器以便提示使用哪种优化方式,这样即影响了优化器的优化方式。另外,用户也可以请求服务器给出优化过程的各种说明,以获知服务器的优化策略,为用户提供了参数基准,以便用户可以重写查询,架构和修改相关服务器配置,便于mysql更高效的运行。

BibiGPT-哔哔终结者 BibiGPT-哔哔终结者

B站视频总结器-一键总结 音视频内容

BibiGPT-哔哔终结者 28 查看详情 BibiGPT-哔哔终结者

优化器并是不关心表使用了哪种存储引擎,但是存储引擎对服务器优化查询的方式是有影响的。优化器需要知道存储引擎的一些特性:具体操作的性能和开销方面的信息,以及表内数据的统计信息。例如,存储引擎支持哪些索引类型,这对于查询是非常有用的。

在解析查询之前,要查询缓存,这个缓存只能保存查询信息以及结果数据。如果请求一个查询在缓存 中存在,就不需要解析,优化和执行查询了。直接返回缓存中所存放的这个查询的结果。

相关阅读:

MySQL体系结构

MySQL MYISAM引擎更改列默认值优化

MySQL的MYISAM引擎不支持事务

关于MySQL MYISAM 表并发

MySQL 数据库清理MYISAM Innodb表

MySQL中MYISAM与InnoDB的区别

 

更多详情见请继续阅读下一页的精彩内容:

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/549337.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 19:14:37
下一篇 2025年11月9日 19:21:46

相关推荐

  • html5导出excel表格_使用前端库生成Excel文件【方法】

    可在%ignore_a_1%中用前端库直接生成Excel:一、SheetJS适合快速导出JSON/HTML为.xlsx;二、exceljs支持样式和公式但体积大;三、HTML表格转.xls为轻量兼容方案。 如果您希望在浏览器中直接生成并导出 Excel 文件,而无需后端参与,则可以借助轻量级前端 J…

    2025年12月23日
    200
  • html 如何弹窗_使用HTML与JavaScript实现弹窗【实现】

    需结合HTML与JavaScript实现弹窗:一、用alert/confirm/prompt;二、自定义模态框(HTML结构+CSS样式+JS控制);三、data属性传参复用;四、禁滚动并聚焦;五、Esc键关闭。 如果您希望在网页中显示一个临时的提示窗口,用于展示信息、确认操作或收集用户输入,则需要…

    2025年12月23日
    200
  • 使用CSS实现可滚动、自适应边界的Flex Wrap容器

    本教程详细阐述了如何纯粹使用CSS,创建一个可滚动且不超出父容器边界的Flex Wrap布局。核心解决方案在于结合父容器的position: relative与子容器的position: absolute、height: 100%、width: 100%及overflow: scroll属性。文章将…

    2025年12月23日
    000
  • java怎么编译运行.html_java编译运行.html方法【教程】

    Java程序的编译运行与HTML无关,需使用JDK。1. 编写HelloWorld.java文件;2. 命令行执行javac HelloWorld.java生成.class文件;3. 执行java HelloWorld运行程序。注意:HTML是网页标记语言,不能直接运行Java代码,勿将二者混淆。确…

    2025年12月23日
    000
  • html文档中含有java怎么运行_html含java运行方法【教程】

    现代浏览器不支持Java Applet,推荐通过JavaScript调用Java后端服务或使用WebAssembly运行Java代码。 如果您在HTML文档中嵌入了Java代码,但发现无法正常运行,这通常是因为现代浏览器不再支持Java小程序(Applet)或相关插件。以下是几种实现HTML中Jav…

    2025年12月23日
    000
  • 怎么运行html的applet小程序_运行html applet小程序步骤【指南】

    现代浏览器已不再默认支持Java Applet,需通过安装JRE、启用插件、使用支持NPAPI的旧版浏览器(如Firefox 52.9 ESR)、调整Java安全级别至中,并将网站添加到例外站点列表方可运行。 如果您在尝试运行HTML中的Applet小程序时遇到问题,可能是因为现代浏览器已不再默认支…

    2025年12月23日
    000
  • 解决HTML表格行间距问题的CSS技巧

    本文旨在解决%ignore_a_1%表格中因元素默认外边距导致的意外行间距问题。通过深入分析,我们发现即使应用`border-collapse: collapse;`,内部块级元素的默认外边距仍可能制造间隙。教程提供了两种有效的css解决方案:一是使用递归选择器统一清除容器内所有子元素的默认外边距;…

    2025年12月23日
    000
  • CSS多行文本截断:无省略号的实现方法

    本文将详细介绍如何在%ignore_a_1%中实现多行文本截断,同时避免显示传统的省略号。通过精确计算文本行高并设置固定容器高度,结合`overflow: hidden`属性,开发者可以实现对溢出文本的干净截断,适用于需要保持页面布局整洁的场景,尤其是在需要避免默认省略号行为时。 在网页设计中,处理…

    2025年12月23日
    000
  • 响应式图片上的标记定位:img-fluid与绝对定位的实践指南

    本教程详细阐述如何在应用了 `img-fluid` 类的响应式图片上精确叠加标记。通过引入一个相对定位的父容器,巧妙地将响应式行为作用于容器而非图片本身,并利用%ignore_a_1%的绝对定位和 `calc()` 函数,实现灵活且精准的坐标定位,尤其解决了标记尖端对齐的挑战,确保在不同屏幕尺寸下标…

    2025年12月23日 好文分享
    000
  • 纯CSS替换标签文本内容的教程

    本教程详细介绍了如何利用纯%ignore_a_1%技术替换html ` `标签的文本内容。我们将探讨两种主要方法:通过`text-indent`将原始文本移出视口,或通过`font-size`将其隐藏,然后结合`::before`伪元素插入新的可见文本。文章将提供具体的css代码示例,并强调这种纯c…

    2025年12月23日
    000
  • CSS实现动态高度内容平滑展开的技巧:使用max-height进行过渡动画

    本文探讨了在web开发中实现动态高度内容平滑展开的常见挑战。由于%ignore_a_1%无法直接对`height: auto`进行过渡动画,导致内容在显示时出现突兀的“跳跃”效果或不必要的间距。文章详细介绍了如何通过巧妙地利用`max-height`属性结合css `transition`来克服这一…

    2025年12月23日
    000
  • 使用CSS :has() 彻底自定义无原生单选按钮的表单元素

    本文详细介绍了如何利用%ignore_a_1%的`:has()`选择器,实现彻底隐藏html原生单选按钮(radio input)并对其父级标签进行完全自定义样式。核心方法是通过将原生单选按钮设置为透明并绝对定位,同时使用`:has()`选择器根据其选中状态来控制父级“元素的背景色等样式,从而在不…

    2025年12月23日
    000
  • JavaScript手风琴组件:实现单面板展开模式

    本教程详细阐述如何优化JavaScript手风琴(Accordion)组件,使其在任何时候都只允许一个面板展开。通过采用事件委托机制,并结合遍历关闭其他面板的逻辑,我们能够有效避免多个面板同时打开的问题,从而提升用户界面的清晰度和交互体验。文章将提供具体的JavaScript代码实现、相关的HTML…

    2025年12月23日
    000
  • 掌握CSS scroll-snap:解决嵌套结构下的滚动吸附问题

    本文详细介绍了%ignore_a_1% `scroll-snap`属性在多层嵌套容器中的应用方法。针对滚动容器内部存在中间层包裹子元素导致吸附失效的问题,文章阐述了如何正确配置`scroll-snap-type`于滚动容器,以及`scroll-snap-align`于吸附目标元素。通过具体代码示例,…

    2025年12月23日
    000
  • 如何解决HTML元素因滚动条导致水平对齐不一致的问题

    本教程旨在解决%ignore_a_1%在水平居中时,因其中一个元素存在滚动条而导致对齐偏差的问题。核心方案是通过精确控制滚动条的出现位置,将其限制在需要滚动的元素内部,并结合css的`box-sizing`属性,确保元素宽度计算的准确性,从而实现不同父级元素间的完美水平对齐。 在网页布局中,我们经常…

    2025年12月23日
    000
  • JavaScript 实现水平滚动菜单的初始居中定位

    本教程详细介绍了如何使用%ignore_a_1%和css构建一个基础的水平滚动菜单,并利用javascript实现菜单内容在页面加载时自动居中显示。通过精确计算滚动容器的宽度和内容宽度,我们可以动态调整`scrollleft`属性,确保用户首次访问时,菜单的中间部分能够呈现在可视区域的中心,从而提升…

    2025年12月23日
    100
  • 使用BeautifulSoup和JSON有效抓取动态加载的网页表格数据

    本教程旨在解决使用BeautifulSoup抓取网页表格时,因数据动态加载导致部分内容缺失的问题。通过分析网页背后的API请求,直接获取并解析JSON数据源,再结合BeautifulSoup提取的HTML结构信息,最终实现完整且准确的数据抓取。文章将提供详细的代码示例和实现步骤。 理解网页动态内容与…

    2025年12月23日
    400
  • 解决BeautifulSoup爬取网页表格中动态内容缺失问题

    本文旨在解决使用BeautifulSoup爬取网页表格时,因部分数据通过JavaScript动态加载导致内容缺失的问题。通过详细分析Oracle云定价页面的案例,教程将指导读者如何识别并获取隐藏在JSON API中的动态数据,并将其与BeautifulSoup解析的静态HTML内容有效整合,最终构建…

    2025年12月23日
    000
  • HTML5怎么实现进度条_HTML5进度条组件开发

    使用HTML5的标签可快速实现进度条,结合CSS和JavaScript能动态更新和美化样式;若需更高灵活性,可用div模拟进度条组件,通过JS控制宽度和文本实现自定义效果。 用HTML5实现进度条其实很简单,主要依赖 标签和少量CSS样式,再结合JavaScript动态控制值即可。如果你需要更灵活的…

    2025年12月23日
    000
  • HTML数据如何存储到数据库 HTML数据存储的技术方案比较

    直接存储原始HTML字符串最常见,适用于富文本编辑器输出等内容,实现简单、读取快,但需防范XSS和SQL注入;结构化JSON存储适合需程序化处理的场景,支持条件查询但渲染开销大;专用格式如Delta适用于协同编辑;分离存储则提升大型系统的查询性能与管理灵活性。 将HTML数据存储到数据库时,核心目标…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信