基础知识
1、MySql中有有哪几种锁?
1、表级锁: 开销小, 加锁快; 不会出现死锁; 锁定粒度大, 发生锁冲突的概率最高, 并发度最低。
2、行级锁: 开销大, 加锁慢; 会出现死锁; 锁定粒度最小, 发生锁冲突的概率最低, 并发度也最
高。
3、页面锁: 开销和加锁时间界于表锁和行锁之间; 会出现死锁; 锁定粒度界于表锁和行锁之间, 并
发度一般。
2、MySQL 中有哪些不同的表格?(存储引擎)
共有 5 种类型的表格: 1、MyISAM2、Heap 3、Merge 4、INNODB 5、MISAM
3、简述在MySQL 数据库中 MyISAM 和InnoDB 的区别
MyISAM:
不支持事务,但是每次查询都是原子的;支持表级锁,即每次操作都是对整个表加锁,存储表的总行数;
一个MyISAM表有三个文件:索引文件、表结构文件、数据库文件;
采用
采用菲聚集索引,索引文件的数据域存储指向数据文件的指针。辅索引主索引基本一致,但是辅索引不用保证唯一性。
InnoDB :
支持 ACID 的事务, 支持事务的四种隔离级别; 支持行级锁及外键约束: 因此可以支持写并发; 不存储总行数:
一个 InnoDb 引擎存储在一个文件空间( 共享表空间, 表大小不受操作系统控一个表可能分布在多个文件里), 也有可能为多个( 设置为独立表空, 表大小受操作系统文件大小限制, 一般为 2G), 受操作系统文件大小的限
主键索引采用聚集索引( 索引的数据域存储数据文件本身), 辅索引的数据域存储主键的值; 因此从辅索引查找数据, 需要先通过辅索引找到主键值, 再访问辅索引; 最好使用自增主键, 防止插入数据时, 为维持 B+树结构, 文件的大调整。
4、CHAR 和VARCHAR 的区别?
CHAR 和 VARCHAR 类型在存储和检索方面有所不同
CHAR 列长度固定为创建表时声明的长度, 长度值范围是 1 到 255 当CHAR 值被存储时, 它们被用空格填充到特定长度, 检索 CHAR 值时需删除尾随空格。
5、myisamchk 是用来做什么的?
它用来压缩MyISAM表,这减少了磁盘或内存使用。
MyISAM Static 和 MyISAM Dynamic 有什么区别?
在 MyISAM Static 上的所有字段有固定宽度。动态 MyISAM 表将具有像 TEXT, BLOB 等字段, 以适应
不同长度的数据类型。
MyISAM Static 在受损情况下更容易恢复。
6、MyISAM 表格将在哪里存储,并且还提供其存储格式?
每个 MyISAM 表格以三种格式存储在磁盘上:
“.frm” 文件存储表
数据文件具有“.MYD”( MYData)
扩展名索引文件具有“.MYI”( MYIndex) 扩展名
7、可以使用多少列创建索引?
任何标准表最多可以创建16个索引。
8、MySQL 支持事务吗?
在缺省模式下,MySQL 是 autocommit 模式的,所有的数据库更新操作都会即时提交, 所以在缺省情况下, MySQL 是不支持事务的。
但是如果你的 MySQL 表类型是使用 InnoDB Tables 或 BDB tables 的话, 你的MySQL 就可以使用事务处理,使用 SET
AUTOCOMMIT=0 就可以使 MySQL 允许在非 autocommit 模式,在非autocommit 模式下,你必须使用 COMMIT 来提交你的更改,或者用 ROLLBACK 来回滚你的更改
9、MySQL 数据库作发布系统的存储,一天五万条以上的增量, 预计运维三年,怎么优化?
- 设计良好的数据库结构, 允许部分数据冗余, 尽量避免 join 查询, 提高效率。
- 选择合适的表字段数据类型和存储引擎, 适当的添加索引。
- MySQL 库主从读写分离。
- 找规律分表, 减少单表中的数据量提高查询速度。5、添加缓存机制, 比如 memcached, apc等。
- 不经常改动的页面, 生成静态页面。
- 书写高效率的 SQL。比如 SELECT * FROM TABEL 改为 SELECT field_1, field_2, field_3 FROMTABLE.
10、锁的优化策略
- 读写分离
- 分段加锁
- 减少锁持有的时间
1. 多个线程尽量以相同的顺序去获取资源
不能将锁的粒度过于细化, 不然可能会出现线程的加锁和释放次数过多, 反而效率不如一次加一把大锁。