mysql

1.MyISAM与InnoDB

(1) MySQL中MyISAM与InnoDB的区别,至少5点:

  1. InnoDB支持事务,而MyISAM不支持事务。
  2. InnoDB支持行级锁,而MyISAM支持表级锁
  3. InnoDB支持MVCC,而MyISAM不支持
  4. InnoDB支持外键,而MyISAM不支持
  5. InnoDB不支持全文索引,而MyISAM支持

(2)       InnoDB引擎的3大特性

  插入缓存(insert buffer)、二次写(double write)、自适应哈希索引(ahi)、预读(read ahead)

(3)二者select count(*)哪个更快,为什么?

  MyISAM更快,因为MyISAM内部维护了一个计数器,可以直接调取。

 

2.如果优化数据库的数据查询,另外应用层上还能如何优化?

1)数据库层面上:

  • 除了主键索引,唯一索引之外,对于常用的查询字段也要加索引。查询的时候尽量使用主键索引,因为MySQL 的 InnoDB 的主键索引索引的是整行数据,而普通索引索引的是主键,会有回表操作。当然索引并不是越多越好,索引固然可以提高相应的 select 的效率,但同时也降低了 insert 及 update 的效率,需要酌情考虑。
  • 优化查询语句,尽量采用确认性查询语句,减少 or,in,not in,%xxx%语法的使用。

2)应用层面上:

  • 采用缓存机制,将常用的数据进行缓存,增加访问速度;
  • 分库分表,读写分离,将数据分开读写,提升性能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值