每日面试题总结 day06

基础知识

每日面试题总结 day06

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 数据库作发布系统的存储,一天五万条以上的增量, 预计运维三年,怎么优化?

  1. 设计良好的数据库结构, 允许部分数据冗余, 尽量避免 join 查询, 提高效率。
  2. 选择合适的表字段数据类型和存储引擎, 适当的添加索引。
  3. MySQL 库主从读写分离。
  4. 找规律分表, 减少单表中的数据量提高查询速度。5、添加缓存机制, 比如 memcached, apc等。
  5. 不经常改动的页面, 生成静态页面。
  6. 书写高效率的 SQL。比如 SELECT * FROM TABEL 改为 SELECT field_1, field_2, field_3 FROMTABLE.

10、锁的优化策略

  1. 读写分离
  2. 分段加锁
  3. 减少锁持有的时间
    1. 多个线程尽量以相同的顺序去获取资源
    不能将锁的粒度过于细化, 不然可能会出现线程的加锁和释放次数过多, 反而效率不如一次加一把大锁。
上一篇:JDK1.8源码(五)——java.util.Vector类


下一篇:四则运算出题系统