分类: Mysql/postgreSQL
2019-05-09 16:10:14
随着互联网技术的迅猛发展,现在逐步渐入大数据、云计算、虚拟技术和人工智能时代,技术为王的现象越来越明显了。现下网站规模越来越大、架构越来越复杂,企业对于运维工程师、架构师的要求也越来越急迫,特别是对有经验的优秀运维人才需求量大,而运维工程师技术含量和要求也会随之越来越高。那么Linux运维学习中MySQL服务器结构中,SQL层如何工作?MySQL学习
1、接收到SQL语句,语法判断。
2、判断语义(判断语句类型:DML、DDL、DCL、DQL)
3、解析SQL语句,生成多种执行计划
4、优化器,选择他认为成本最低的执行计划。
5、执行器根据优化器的选择,按照优化器建议执行SQL语句,得到去哪儿找SQL语句需要访问的数据
5.1 具体:在哪个数据文件上的哪个数据页中?
5.2 将以上结果充送给下层继续处理
6、接收存储引擎层的数据,结构化成表的形式,通过连接层提供的专用线程,将表数据返回给用户。
7、提供查询缓存
7.1 query_cache, 使用memcache 或者redis 替代
8、日志记录(binlog)
想要众多的IT工作者中脱颖而出,就需要拥有高深的技术,学习增值是必不可少的。学习之路,是贵在坚持的。