Java常见面试题(二)

MySQL部分

  1. Mysql的常用存储引擎和区别?
    原文链接
  2. Mysql数据量多大时需要分表?
    索引如果建的合适 一千万是没什么问题的 如果改表写入比较频繁 那就稍微早点采取分表操作
  3. 数据库的分库分表的场景及对应的方案?
    原文链接
  4. Mysql中有几种锁?
    MySQL的锁机制比较简单,其最 显著的特点是不同的存储引擎支持不同的锁机制。比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。
    表级锁: 开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
    行级锁: 开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
    页面锁: 开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般
    从上述特点可见,很难笼统地说哪种锁更好,只能就具体应用的特点来说哪种锁更合适!仅从锁的角度 来说:表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用;而行级锁则更适合于有大量按索引条件并发更新少量不同数据,同时又有 并发查询的应用,如一些在线事务处理(OLTP)系统。
    Java常见面试题(二)
  5. Mysql中记录货币用什么字段好?
    使用decimal或者numric类型。
  6. Mysql中InnoDB支持的四种事务隔离级别,以及逐级之间的区别?
    脏读:一个事务读取到另一个事务未提交的数据,这个情况叫脏读
    不可重复读:一个事务读取到另外一个已经提交的事务的数据,导致事务提交前后读取到的内容不一致,这种现象称之为不可重复读
    虚读/幻读:一个事务读取到另外一个事务已经提交的数据,最后做出的整表操作,这种情况称之为虚读/幻读(一般不会出现)Java常见面试题(二)
  7. 如下表
    Java常见面试题(二)
    请写出学生 课程成绩信息列表,并按学号排序的SQL
    请写出查询又三门课程成绩优医生的学生的信息的 SQL(请写出平均成绩几个的所有学生信息,并按学号排序的SQL)