Mysql深入理解(1)】的更多相关文章

/********************************************************************************* * MySQL 存储过程理解 * 说明: * 挺久以前听梦真说过存储过程,不过一直没有去理解到底是什么,今天想到,就查点 * 资料,看一下到底什么. * * 2017-11-6 深圳 南山平山村 曾剑锋 *****************************************************************…
问题:请讲下对mysql的理解 分析:该问题主要考察对mysql的理解,基本概念及sql的执行流程 回答要点: 主要从以下几点去考虑, 1.mysql的整体架构? 2.mysql中每一个组件的作用? 3.对mysql的自己的见解? 从网上拷贝一张图,来说明mysql的整体架构 个人认为这张图画的很好, 连接器 一条sql经过网络传输到达mysql服务器,第一个要经过的就是连接器,负责连接的建立及权限的判定,例如经常看到的下面的错误, ERROR 1045 (28000): Access deni…
目录 一.MYSQL架构 1. 架构图 2.分层实现 3.查询组件 二.并发控制 三. 事务 四.引擎 摘自 通过对MYSQL重要的几个属性的理解,建立一个基本的MYSQL的知识框架 一.MYSQL架构 这里给的架构描述,是很宏观的架构.有助于建立对MYSQL整体理解 1. 架构图 以下是在网上找的两张MYSQL架构图.能反映MYSQL的结构 结构基本一致,都是连接.服务和存储引擎三部分. 2.分层实现 MYSQL大致分为3个层次.连接层.服务层和引擎层. 连接层功能是客户端的链接服务. 服务层…
转载:http://www.hollischuang.com/archives/934 在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数据时不破坏事务的隔离性和统一性以及数据库的统一性. 乐观并发控制(乐观锁)和悲观并发控制(悲观锁)是并发控制主要采用的技术手段. 无论是悲观锁还是乐观锁,都是人们定义出来的概念,可以认为是一种思想.其实不仅仅是关系型数据库系统中有乐观锁和悲观锁的概念,像memcache.hibernate.tair等都…
出处:http://blog.codinglabs.org/articles/theory-of-mysql-index.html   摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BTree索引,哈希索引,全文索引等等.为了避免混乱,本文将只关注于BTree索引,因为这是平常使用MySQL时主要打交道的索引,至于哈希索引和全文索引本文暂不讨论.…
[存储引擎] InnoDB表引擎 默认事务型引擎,最重要最广泛的存储引擎,性能非常优秀. 数据存储在共享表空间,可以通过配置分开. 对主键查询的性能高于其他类型的存储引擎. 内部做了很多优化,从磁盘读取数据时自动在内存构建hash索引,插入数据时自动构建插入缓冲区. 通过一些机制和工具支持真正的热备份,支持崩溃后的安全恢复,支持行级锁,支持外键. MyISAM表引擎 mysql5.1版本之前的默认存储引擎 ,拥有全文索引.压缩.空间函数. 不支持事务和行级锁,支持表锁,不支持奔溃后的安全恢复.…
主要包括存储引擎.索引.sql语句 一.存储引擎 目前最常见的是InnoDB和MyISAM两个存储引擎 (1)InnoDB:支持事务处理,提供行级锁.外键约束索引,行锁 (2)MyISAM:支持全文搜索,表锁 对于经常需要增删改操作的表建议使用InnoDB,因为有事务处理(要么成功要么失败回滚),而需要大量查询操作的表建议用MyISAM 二.索引 索引可以大大提高MySQL的检索速度 (1)普通索引:由关键字KEY或INDEX定义的索引,唯一任务就是加快访问速率 (2)唯一索引:索引列的值必须唯…
在之前的面试过程中,有被问到很多次,关于MySQL数据库相关知识,其中有问到了解存储引擎,数据库优化等问题,问得一脸懵X,确实以前在学习的时候没有去深入了解过这一块儿,今天找到了相应的数据库视频,稍稍做一点点总结. 一.MySQL数据库的存储引擎分类 如下图所示: 从上图可以看出,各种存储引擎之间的区别: 其中MySql5.5版本默认使用的是InnoDB存储引擎.当然,其中也有提到关于锁的概念. 特别对比: MyISAM :存储限制可达256TB,支持索引.表级别锁以及数据压缩. InnoDB…
一.关系型数据主要: 1.架构,2.索引,3.锁,4.语法,5.理论范式 二.设计一个关系型数据库有哪些模块: 存储管理,缓存机制,Sql解析,日志管理,权限划分,容灾机制,索引管理,锁管理管理 1.为什么要使用索引 避免全表扫描,源于字典 2.数据记录中有哪些数据能够成为索引 主键,唯一键以及普通键等 3.索引的数据结构 生成索引,建立二叉查找树进行二分查找 生成索引,建立B-Tree结构进行查找 生成索引,建立B+-Tree结构进行查找(mysql 主要用的是这个) 生成索引,建立Hash结…
什么是数据库? 存储数据的仓库,本质是一个文件系统,封装了算法和文件之前数据的存储模式 阶段1:集合 数组 变量 缺点:数据存储在内存中,不能实现数据的持久化存储 阶段2:IO流 结合文件 .txt .xml.... 优点:数据存储在磁盘上,数据可以实现持久化存储 缺点:数据操作时,算法必须自己实现,但是相当一部分算法实现重复 阶段3:数据库 优点:使用专门的程序封装了算法部分 数据库与IO比较:算法 + 文件存储数据数据库结构: 算法部分:.exe程序 lib文件夹下 文件存储部分:以文件和文…