浏览 5562 次
锁定老帖子 主题:Mysql中SQL使用总结(一)
精华帖 (1) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2012-01-11
现在的工作环境跟MySQL打的交道比较多,把平时工作中遇到的有意思SQL的部分总结一下. 知识来源:看书,工作总结,官方文档... 从哪开始呢,先从基本结构开始吧:ok let's go. 1:先看MySQL整体模块图: (图片取自MySQL核心技术) 从图中可以看出MySQL的模块职责分工明确,不愧是Monty团队20年的结晶.好产品是靠持续的汗水浇灌的啊(扯远了)。。。 其中MySQL语句大概分两种:SQL和命令 SQL无非就是DDL,DML,命令是mysql自身语法如:show [table,process,database,index] , source ...等等. 用一条DML为例,连接管理器模块,线程模块,权限模块职责很明确此处略. 第一步由Commander Dispatcher(命令)模块统一接受处理, 1)如果开启全查询日志(是log 不是slow-low),会记录所有的语句(包括错误语句) 2)如果开启查询缓存(query_cache_type=1)会先判断语句是否可缓存,如果可以使用语句和客户端信息等的hash值查询query cache模块 如果找到数据短路. 第二步将语句转交parser模块进行解析,并发送给不同模块(优化器,表修改模块,表维护模块,复制模块,状态模块等) 其中最重要的是优化器模块,这个是所有数据库的核心,所有的DML都经过它完成 (这个后面的文章做进一步总结和学习,sql的快与慢全靠他.) 第三步假如进入优化器模块:MySQL的优化器的只定义了抽象存储引擎(Handler) 具体实现由存储引擎完成(mysql的插件引擎特性) 第四步进入存储引擎内部完成具体的数据读取和修改,内部有很复杂的处理流程和日志体系(如:innodb buffer_pool,redo,undb等..). 第五步返回数据,如果开启查询缓存会做尝试做缓存.最后完成清理工作,回收线程. 这里非常粗粒度的介绍的MySQL模块见的相互配合完成sql的过程,具体流程比这复杂的多,正在看书并结合源码研究中。。 简单语句流程到这里,MySQL下面看看另一张关注parser, optimizer的流程图 (图片取自高性能MySQL) 这张图更能体现sql的一些解析处理和优化过程. 这里有个问题需要介绍以下MySQL没有全局sql字节码缓存,所有的语句都要解析成语法树. 如果使用PrepareStatement的机制发送SQL 则mysql只在当前session支持预编译 官方解释如下: http://dev.mysql.com/doc/refman/5.1/en/sql-syntax-prepared-statements.html 这里和Oracle由很大不同,也就是说你没有使用变量绑定,MySQL也不会像Oracle那样迅速被拖慢... mysql有SQL服务器模式,通过sql-mode参数体现. 可以随时更改自己的会话 sql_mode值 主要sql_mode取值如下: · ANSI: · STRICT_TRANS_TABLES: ·TRADITIONAL ·ALLOW_INVALID_DATES ·ANSI_QUOTES ·ERROR_FOR_DIVISION_BY_ZERO ·HIGH_NOT_PRECEDENCE 查看官方文档解释:http://dev.mysql.com/doc/refman/5.1/zh/database-administration.html#server-sql-mode 你在mysql中遇到不一致的sql执行结果时,记得看看你session的sql_mode 开始部分只是粗粒度介绍下MySQL 关于sql的地方,后面会陆续把sql执行细节,优化过程和工作中的问题拿出来分享一下,希望与各位交流讨论. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2012-02-02
看样子是系列连载,收藏下吧
|
|
返回顶楼 | |
发表时间:2012-02-02
果然粒度很粗
|
|
返回顶楼 | |
发表时间:2012-02-03
虾米啊,,,感觉它能埋了我的路过
|
|
返回顶楼 | |
发表时间:2012-02-04
很有深度,学习了
|
|
返回顶楼 | |