一.常见存储引擎 1.1 InnoDB InnoDB 是 MySQL 5.5 之后默认的存储引擎,它具有高可靠.高性能的特点,主要具备以下优势: DML 操作完全遵循 ACID 模型,支持事务,支持崩溃恢复,能够极大地保护用户的数据安全: 支持多版本并发控制,它会保存数据的旧版本信息,从而可以支持并发和事务的回滚: 支持行级锁,支持类似 Oracle 的一致性读的特性,从而可以承受高并发地访问: InnoDB 组织数据时默认按照主键进行聚簇,从而可以提高主键查找的效率.对于频繁访问的数据,Inn…
##一.基础 ## *    插入                   INSERT INTO table_name ( field1, field2,...fieldN )                                        VALUES                                        ( value1, value2,...valueN ); *    修改                                update t…
以下内容翻译自mysql5.6官方手册. InnoDB是一种通用存储引擎,可平衡高可靠性和高性能.在MySQL 5.6中,InnoDB是默认的MySQL存储引擎.除非已经配置了不同的默认存​​储引擎,否则发出没有ENGINE =子句的CREATE TABLE语句会创建一个InnoDB表. InnoDB的主要优势包括: 其DML操作遵循ACID模型,具有提交,回滚和崩溃恢复功能的事务以保护用户数据. 行级锁定和Oracle风格一致的读取增加了多用户并发和性能. InnoDB表将您的数据安排在磁盘上…
一.索引 1.1 索引的概念 索引是一个排序的列表,存储着索引值和这个值所对应的物理地址 无须对整个表进行扫描,通过物理地址就可以找到所需数据 (数据库索引类似书中的目录,通过目录就可以快速査找所需信息) 1.2 索引的作用 建立索引之后,数据库利用各种快速定位技术,能够大大加快查询速率 当表很大或查询涉及多个表时,可以成千上万倍的提高查询速度 可以降低数据库的IO成本,还可以降低数据库的排序成本 通过创建唯一性索引保证数据表数据的唯一性 可以加快表与表之间的连接 1.3 索引的优缺点 优点:可…
mysql在线修改表结构大数据表的风险与解决办法归纳 - 王滔 - 博客园 http://www.cnblogs.com/wangtao_20/p/3504395.html MySQL 加索引 加字段 锁表问题-CSDN问答https://ask.csdn.net/questions/261051 MySQL中的锁(表锁.行锁) - 雪山飞猪 - 博客园https://www.cnblogs.com/chenqionghe/p/4845693.html MySQL 加索引 加字段 锁表问题-CS…
在表中有这么一索引 UNIQUE KEY `customer_id` (`customer_id`,`item_id`,`ref_id`) 问1. 这种多列唯一索引在事务中select for update下是不是行锁? 如下: 事务1, CREATE DEFINER=`root`@`localhost` PROCEDURE `Test1`(out debitb decimal(14,2))BEGIN -- SET TRANSACTION ISOLATION LEVEL Serializable…
本文源码:GitHub·点这里 || GitEE·点这里 一.锁概念简介 1.基础描述 锁机制核心功能是用来协调多个会话中多线程并发访问相同资源时,资源的占用问题.锁机制是一个非常大的模块,贯彻MySQL的几大核心难点模块:索引,锁机制,事务.这里是基于MySQL5.6演示的几种典型场景,对面MySQL这几块问题时,有分析流程和思路是比较关键的.在MySQL中常见这些锁概念:共享读锁.排它写锁 ; 表锁.行锁.间隙锁. 2.存储引擎和锁 MyISAM引擎:基于读写两种模式,支持表级锁 ; Inn…
MySQL 索引.事务与存储引擎 目录 MySQL 索引.事务与存储引擎 MySQL 索引 索引的概念 索引的作用及副作用 索引的作用 索引的副作用 创建索引的原则依据 索引的分类和创建 普通索引 唯一索引 主键索引 组合索引(单列索引与多列索引) 全文索引(FULLTEXT) 查看索引 删除索引 MySQL事务 事务的概念 事务的ACID特点 原子性 一致性 隔离性 MySQL事务隔离级别 查询全局事务隔离级别 查询会话事务隔离级别 设置全局事务隔离级别 设置当前会话事务隔离级别 持久性 小结…
基础篇:MySql架构与存储引擎 逻辑架构图: 连接层: mysql启动后(可以把mysql类比为一个后台的服务器),等待客户端请求,当请求到来后,mysql建立一个一个线程处理(线程池则分配一个空线程,当然也可使用nio线程模型.),每个线程独立,拥有独自内存空间.当请求为select请求则没有关系,但是请求为update时,多线程同时修改一块内存,就会引发一系列问题,由此引出 “锁“的概念. 查看mysql当前连接数: show VARIABLES like '%max_connection…
本文主要是针对MySQL/InnoDB的并发控制和加锁技术做一个比较深入的剖析,并且对其中涉及到的重要的概念,如多版本并发控制(MVCC),脏读(dirty read),幻读(phantom read),四种隔离级别(isolation level)等作详细的阐述,并且基于一个简单的例子,对MySQL的加锁进行了一个详细的分析.本文的总结参考了何登成前辈的博客,并且在前辈总结的基础上,进行了一些基础性的说明,希望对刚入门的同学产生些许帮助,如有错误,请不吝赐教.按照我的写作习惯,还是通过几个关键…