一、简答题
1.简述你们公司使用的MySQL版本,并说明具体小版本及GA时间?
5.7.20
5.6.38
2017.9.13
2.请介绍你熟悉的数据库关系系统的种类和代表产品名称?
NoSQL:Redis Mongodb memecache
RDBMS:Oracle MySQL MSSQL PG
3.请简述MySQL二进制安装重点步骤?
1.下载,上传,解压
2. 创建用户
3. 创建相关目录并授权
4. 设置环境变量
5. 初始化数据
6. 配置文件
7. 配置启动脚本
4.怎么确认数据库启动成功了?
netstar -lnp | grep 3306
ps -ef | grep mysqld
ss -lnp|grep 3306
直接登录数据库
5.简述你了解的MySQL分支版本情况?
Oracle MySQL
MariaDB
Percona
6.请简述mysqld的程序结构(1条SQL语句的执行过程)
连接层:提供连接协议,验证用户,建立专属连接线程
SQL层:语义、语法、权限,解析,优化,执行,查询缓存,日志记录
存储引擎层:相当于Linux文件系统,例如:InnoDB提供了事务,CSR,热备,MVCC,行级锁等
7.请简述你了解的MySQL的启动方式
systemd
mysqld
8.简述MySQL配置文件默认读取顺序
mysqld --help--verbose|grep "my.cnf"
9.mysqld_safe --default-files=/opt/my.cnf &是什么作用?
指定数据库配置文件,并后台运行
10.忘记管理员root的密码处理过程,请对参数详细说明
--skip-grant-tables 关闭连接层的验证功能
--skip-netwoking 关闭TCPIP协议
11.请列举SQL语句的常用种类
DDL
DCL
DQL
DML
12.请说明聚集索引和辅助索引的区别
辅助索引的叶子节点只存储有序的某个列的=值;
聚集索引存储的是整行数据
辅助索引一般配合聚集索引使用,通过辅助索引 找到主键值,然后通过聚集索引找到数据行
减少了回表查询所带来的随机IO
13.请简述以下语句执行计划可能存在的问题
阐述以下语句可能存在的问题,并提出合理解决方案
explain select * from city where countrycode='CHN' order by population;
1. countrycode没有走索引,有可能是没建立索引,或者是索引失效
2. 出现了filesort文件排序,orderby条件也没走索引
建议:
1. 如果没有索引导致,建立联合索引(countrycode,population)
2. 如果是索引失效,删除索引重建
简述出现以下结果的可能原因
怀疑是 telnum列是字符串类型,可能出现了隐式转换,需要进一步判断数据类型
14. 请简述,影响索引树高度的因素?
数据量级:分表分库分布式
索引键值太长:前缀索引
数据类型:char varchar选择,enum,选择合理的数据类型
15.请说明数据库启动失败的处理思路?
如果有日志看日志,如果没有日志mysqld直接启动
16. MySQL索引的种类都有哪些?
R树
B树
hash
17. 你了解的MySQL存储引擎种类有哪些?
InnoDB MyiAM CSV
18.InnoDB存储引擎核心特性
事物、CSR、MVCC、热备、外键、行级锁
二、操作题
1.创建管理员用户:oldboy能通过10.0.0.0/24网段任意地址登录管理MySQL
grant all on *.* to oldboy@10.0.0.0/24 identified by '123';
2.创建应用用户:wordpress能通过172.16.1.0/24网段任意地址登录操作wordpress库下的所有表
grant select,update,delete,insert on wordpress.* to wordpress@172.16.1.0/24 identified by '123';
3.请写出/etc/my.cnf的基础配置信息
[mysqld]
user=mysql
basedir=/application/mysql/
datadir=/data/mysql/data/
socket=/tmp/my.sock
server_id=1
[mysql]
socket=/tmp/my.sock
4.请写出使用oldboy用户远程登录MySQL的具体语句
mysql -uroot -p -h 10.0.0.51 -P3306
5.查看当前数据库的字符集
show charset;
6. 创建GBK字符集的数据库oldboy,并查看已建库完整语句
create database oldboy charsetgbk; (创建用户)
show create database oldboy; (查询建库语句)
7. 请分别介绍 NOT NULL default auto_increament 的作用
NOT NULL:非空
default :默认值
auto_increament:自增
8. 创建用户oldboy,使之可以管理数据库oldboy
grant all on oldboy.* to oldboy@10.0.0.0/24 identified by '123';
9. 收回oldboy用户的drop权限
revoke drop on oldboy.* from oldboy@'10.0.0.%';
10. 查看创建的用户oldboy拥有哪些权限
show grants for oldboy@'10.0.0.%';