测试题

一、简答题

1.简述你们公司使用的MySQL版本,并说明具体小版本及GA时间?

答:刚去上家公司不到两年,交接的时候已经运行了2年多了,我接手的时候版本已经是5.7.20,应当是做过小版本的升级。

2.请介绍你熟悉的数据库关系系统的种类和代表产品名称?

答:RDBMS: Oracle ,MySQL ,PG,MSSQL

NoSQL: MongoDB ,Redis ,ES

NEWSQL: TiDB,Spanner ,AliSQL ,OB ,PolarDB

3.请简述MySQL二进制安装重点步骤?

答:1下载并上传软件到指定目录

2解压软件

3出始化环境

4设置环境变量

5创建路径并授权

6初始化数据

7配置文件的准备

8上完就可以启动数据库

4.怎么确认数据库启动成功了?

答:1最直接就登录数据库mysql -uroot -p

2查看端口进程netstat -lntup|grep 3306、 netstat -lntup|grep mysql

5.简述你了解的MySQL分支版本情况?

答:5.6 : 5.6.34 5.6.36 5.6.38(2017913) 5.6.40

5.7 : 5.7.18 ,20(2017913) ,24 ,26

8.0 : 8014, 8015 ,8016

6.请简述mysqld的程序结构(1条SQL语句的执行过程)

答:先从连接层:1提供连接协议socket,tcp/ip 2验证用户名密码合法性,进行匹配的授权表 3派生一个专用的连接线程(接收sql,返回结果)

在sql层,1验证语法 2验证语义 3验证权限 4解析器语句解析,生成执行计划5优化器算出最优方案这里指代价最低的方案代价指cpu io mem 6执行器按优化给出的最优方案 7查询缓存 8 记录日志

7.请简述你了解的MySQL的启动方式

答:1. sys-v :service mysqld restart  2. Systemd

8.简述MySQL配置文件默认读取顺序

答:命令行>配置文件>预编译

9.mysqld_safe --default-files=/opt/my.cnf &是什么作用?

答:维护模式:忘记密码重置用

10.忘记管理员root的密码处理过程,请对参数详细说明

答:1. 挂维护页 2. 关数据库systemctl stop mysqld 3. 跳过授权启mysqld_safe --skip-grant-tables --skip-networking &--skip-grant-tables : 连接层关闭验证模块,所有验证表不加载。--skip-networking :连接层关闭TCP/IP协议,禁止远程访问。4. 改密码mysql> alter user root@'localhost'identified by'123';

ERROR1290(HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statementmysql 报错

mysql> flush privileges;

Query OK,0rows affected (0.00sec)

mysql> alter user root@'localhost'identified by'456';Query OK,0rows affected;

systemctl start mysqld5.正常开启业务

11.请列举SQL语句的常用种类

答: DDL:数据定义语言    data definition language

DCL:数据控制语言    data control language

DML:数据操作语言    data manipulation language

DQL:数据查询语言    data query language

12.请说明聚集索引和辅助索引的区别

答: 1聚集索引只能有一个,非空唯一,一般时主键

2辅助索引,可以有多个,时配合聚集索引使用的

3聚集索引叶子节点,就是磁盘的数据行存储的数据页

4MySQL是根据聚集索引,组织存储数据,数据存储时就是按照聚集索引的顺序进行存储数据

5辅助索引,只会提取索引键值,进行自动排序生成B树结构

13.请简述以下语句执行计划可能存在的问题

阐述以下语句可能存在的问题,并提出合理解决方案

explain select * from city where countrycode='CHN' order by population;

简述出现以下结果的可能原因

答:文件排序问题desc select count(distinct countrycode,population ) from world.city; 文件排序重复Using filesort

14. 请简述,影响索引树高度的因素?

答: 1. 数据量级, 解决方法:分表:分库,分布式

2. 索引列值过长 , 解决方法:前缀索引-->取前几个

3. 数据类型:变长长度字符串,使用了char,解决方案:变长字符串使用varchar enum类型的使用enum('山东','河北','黑龙江','吉林','辽宁','陕西'......)123

15.请说明数据库启动失败的处理思路?

答: 查看日志:在哪?

/data/mysql/data/主机名.err

[ERROR] 上下文

可能情况:/etc/my.cnf 路径不对等

/tmp/mysql.sock文件修改过 或 删除过

数据目录权限不是mysql

参数改错了

16. MySQL索引的种类都有哪些?

答: B树索引

Hash索引

R树

Full text

GIS

17. 你了解的MySQL存储引擎种类有哪些?

答: InnoDB MyISAM CSV MEMORY ARCHIVE

其他MySQL的引擎

PerconaDB:默认是XtraDB

MariaDB:默认是InnoDB

其他的存储引擎支持:

TokuDB   

RocksDB

MyRocks

18.InnoDB存储引擎核心特性

答:1、事务(Transaction)

2、MVCC(Multi-Version Concurrency Control多版本并发控制)

3、行级锁(Row-level Lock)

4、ACSR(Auto Crash Safey Recovery)自动的故障安全恢复

5、支持热备份(Hot Backup)

6、复制Replication: Group Commit , GTID (Global Transaction ID) ,多线程(MTS,Multi-Threads-SQL )

二、操作题

1.创建管理员用户:oldboy能通过10.0.0.0/24网段任意地址登录管理MySQL

答:grant all on oldboy.* to oldboy@’10.0.0.%’ identified by ‘123’

2.创建应用用户:wordpress能通过172.16.1.0/24网段任意地址登录操作wordpress库下的所有表

答:grant all on wordpress.* to wordpress@'172.16.1.%' identified by '123';

3.请写出/etc/my.cnf的基础配置信息

答:[mysqld]

User=mysql

Basedir=/application/mysql

Datadir=/data/mysql/data

Socket=/tmp/mysql.sock

Server_id=6

Port=3306

Log_error=/data/mysql/data/mysql.log

Log_bin=/data/mysql/data/mysql-bin

[mysql]

Socket=/tmp/mysql.sock

4.请写出使用oldboy用户远程登录MySQL的具体语句

答:mysql -uoldboy -p -h10.0.0.51

5.查看当前数据库的字符集

答:show create database oldboy;

6. 创建GBK字符集的数据库oldboy,并查看已建库完整语句

答:create database oldboy chart GBK;

show create database oldboy;

7. 请分别介绍 NOT NULL default auto_increament 的作用

答:非空 默认值 自增

8. 创建用户oldboy,使之可以管理数据库oldboy

答:grant all on oldboy.* to oldboy@’%’ identified by ‘123’;

9. 收回oldboy用户的drop权限

答:revoke drop on oldboy.* from oldboy@’%’;

10. 查看创建的用户oldboy拥有哪些权限

答:show grant for odlboy@’%’;

11. 查看建表结构及表结构的SQL语句

答:show create table world.city

desc world.city;

12. 插入一条数据“1,oldboy”

答:insert into city(id,name) valuas(1,oldboy);

13.再批量插入2行数据“2,老男孩”,“3,oldboyedu”

答:insert into city(id,name) valuas(2,老男孩);(3,oldboyedu);

14.查询名字为oldboy的记录

答:use world    Select * from city where name=’oldboy’;

15. 查看数据库中所有引擎的类型

答:show engines;

16.查看数据库关于日志的参数配置

答:select @@general_log_file;

17.查看handler_read_key当前的状态信息

答:show status like 'handler_read_key';

18. 列出删除表中数据的方式

答:alter table city drop id;

alter table city drop id where ‘id=1’;

19.test表中,有id、 name、shouji列。把id列设置为主键,在Name字段上创建普通索引

答:alter table test add primary key idx_id(id);

Alter table test add index idx_name(name);

20. 在手机字段上对前8个字符创建普通索引

答:alter table test add index idx_sj(shouji(8));

21.查看创建的索引及索引类型等信息

答:show index from test\G;

22.删除Name,shouji列的索引

答:alter table test drop index name;

Alter table test drop index shouji;

23.对Name列的前6个字符以及手机列的前8个字符组建联合索引

答:alter table test add index idx_name_shouji(name(6),shouji(8));

24. 将shouji列索引替换为唯一键索

答:alter table test add uqique index idx_shouji(shouji);

25.如何查看world数据库下city表中population列的重复值情况

答: select name,count(population) from city group by name limit 5;

26. 请列出explain命令中type中多种类型

答:

all :没有使用索引

index:全索引扫描

range:索引范围查找

ref:辅助索引的等值查询

eq_ref:多表连接的表.on的条件是主键或者唯一键

system或const:主键或唯一键的等值查询

null:没有结果

27.Select查询语句加强练习

统计世界上每个国家的总人口数.

答:select countrycode,sum(population) from city group by countrycode;

统计中国各个省的总人口数量

答:select District,sum(population) from city where countrycode='CHN' group by District;

统计世界上每个国家的城市数量

答:select country.name,count(city.name) from city join country on country.code=city.CountryCode group by city.countrycode;

统计中国每个省的总人口数,将总人口数小于100w进行从高到低排序显示

select District,sum(population) from city where countrycode='chn' group by District  having sum(population)<1000000 order by sum(population) desc;

28.生成整个数据库下的所有表的单独备份语句

SELECT CONCAT("mysqldump -uroot -p",TABLE_SCHEMA," >/tmp/",TABLE_SCHEMA,"_",TABLE_NAME,".sql")

FROM TABLES INTO OUTFILE '/tmp/bak.sh’

29. SQL综合练习

1. 查询平均成绩大于60分的同学的学号和平均成绩;

2. 查询所有同学的学号、姓名、选课数、总成绩;

3. 查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分

4. 统计各位老师,所教课程的及格率

5. 查询每门课程被选修的学生数

6. 查询出只选修了一门课程的全部学生的学号和姓名

7. 查询选修课程门数超过1门的学生信息

8. 统计每门课程:优秀(85分以上),良好(70-85),一般(60-70),不及格(小于60)的学生列表

9. 查询平均成绩大于85的所有学生的学号、姓名和平均成

你可能感兴趣的:(测试题)