MySQL-第一阶段测试

一、简答题

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

5.7.20 发布时间2017年9月

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

NoSQL:Redis Mongodb memecache

RDBMS:Oracle MySQL MSSQL PG

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

下载二进制包

修改环境变量

清理历史软件包

创建用户

修改目录权限

初始化库

准备启停脚本和创建配置文件

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

ps -ef |grep mysqld

netstat -lnp|grep 3306

ss -lnp|grep grep 3306

mysql 登陆测试

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

oracle MySQL

MariaDB

Percona

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

连接层:

提供连接协议,验证,专用连接线程

SQL层

语法,语义,权限,解析,优化,执行,查询缓存,日志记录

存储引擎层

相当于Linux文件系统,例如:InnoDB提供了事务,CSR,热备,MVCC,行级锁等

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

mysql_safe方式启动

由mysql/bin/mysqld启动

将mysqld复制到etc/init.d目录下可以使用systemctl start mysqld启动

不管哪一种方式,最终调用的都是mysqld文件

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

/etc/my.cnf

/etc/mysql/my.cnf

/usr/local/mysql/etc/my.cnf

~/.my.cnf

命令行参数信息

从上至下,下面的参数信息会覆盖之前读取到的,最终以命令行输入为准

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

&是将其放在后台加载

命令意思是指定加载的配置文件的位置

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

首先关闭MySQL,网站挂维护页

停止服务:systemctl stop mysqld(主要看使用什么方式启动的)

然后执行:mysqld_safe --skip-grant-tables --skip-networking &

skip-grant-tables是跳过用户密码验证模块启动

skip-networking是跳过TCP/IP连接方式模块,不允许用户远程连接

& 放在后台运行

然后直接输入用户名登录数据库

因为关闭了密码验证模块,所以密码没有被加载到内存中,手动加载一下

flush privileges;

然后修改密码

alter user root@'localhost' identified by '123'

然后退出数据库,关闭数据库,重新正常启动即可

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

DDL:数据定义语言

DCL:数据控制语言

DML:数据操作语言

DQL:数据查询语言

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

聚集索引:叶子节点存储的是源文件的内容,聚集索引生成在主键列上,聚集索引是在建表时创建的

辅助索引:叶子节点存放的是数据行在表中的位置,辅助索引可以是任何一列,

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

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

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

image.png

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

image.png

执行速度慢,执行计划为空,全局扫描,

解决方案

countrycode列和population创建联合辅助索引

命令改为select * from city where countrycode='CHN'

原因:

最后的参数没有加引号被识别为了数字,加引号后背时别为字符串,执行过程使用了索引,加快了速度

请简述,影响索引树高度的原因?

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

受数据量级影响:分库分表分布方式

索引列值过长:前缀索引

数据类型:char varchar选择,enum,选择合理的数据类型

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

查看命令行报错,查看mysql错误日志,

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

B树索引,R树索引,hash索引

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

innoDB,MyISAM,memory

18.InnoDB存储引擎核心特性

事务安全(ACID)

MVCC(Multi-Versioning Concurrency Control,多版本并发控制)

InnoDB 行级别锁定

Oracle 样式一致非锁定读取

表数据进行整理来优化基于主键的查询

支持外键引用完整性约束

大型数据卷上的最大性能

将对表的查询与不同存储引擎混合

出现故障后快速自动恢复

用于在内存中缓存数据和索引的缓冲区池

二、操作题

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

grant all on . to oldboy@'10.0.0.%' identified by '123’;

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

grant select,update,delete,insert on wordpress.* to wordpress@'172.16.1.%' identified by '123';

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

[mysqld]

user=mysql

basedir=/usr/local/mysql

datadir=/data/mysql

socket=/tmp/mysql.sock

server_id=1

port=3306

[mysql]

socket=/tmp/mysql.sock

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

mysql -uoldboy -p -h10.0.0.51 -p3306

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

show charset;

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

create database oldboy charset GBK;

show create database oldboy;

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

not null:非空,不能为空

default:默认填写什么

auto_increament:自增长,多用于ID列

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

grant all on oldbooy.* to oldboy@'%' identified by '123456’;

9. 收回oldboy用户的drop权限

revoke drop on oldboy.* from oldboy@’10.0.0.%’;

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

show grants for oldboy@’10.0.0.%’;

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

show create table city;

desc city;

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

insert into db(id,sname) values('1','oldboy');

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

insert into db(id,sname) values('2','老男孩'),('3','oldboyedu');

14.查询名字为oldboy的记录

select * from db where sname='oldboy';

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

show engines;

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

select @@general_log_file;

show variables like '%log%';

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

show status like 'handler_read_key';

show status like 'handler_read_key';

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

alter table db drop id;

alter table db 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_shou(shouji(8));

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

show index from db\G;

22.删除Name,shouji列的索引

alter table db drop index name;

alter table db 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 unique index idx_shouji(shouji);

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

select population,count(id) from world.city group by population having count(id)>1 order by count(id) desc ;

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分的同学的学号和平均成绩;

select S#,avg(score)

from sc

group by S# having avg(score) >60;

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

select Student.S#,Student.Sname,count(SC.C#),sum(score)

from Student left Outer join SC on Student.S#=SC.S#

group by Student.S#,Sname

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

SELECT L.C# As 课程ID,L.score AS 最高分,R.score AS 最低分

FROM SC L ,SC AS R

WHERE L.C# = R.C# and

L.score = (SELECT MAX(IL.score)

FROM SC AS IL,Student AS IM

WHERE L.C# = IL.C# and IM.S#=IL.S#

GROUP BY IL.C#)

AND

R.Score = (SELECT MIN(IR.score)

FROM SC AS IR

WHERE R.C# = IR.C#

GROUP BY IR.C#

);

自己写的:select c# ,max(score)as 最高分 ,min(score) as 最低分 from dbo.sc group by c#

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

SELECT

te.tname,

st.sname,

***sc.score ***

FROM

teacher AS te

JOIN course AS co ON te.tno = co.tno

JOIN sc ON co.cno = sc.cno

***JOIN student AS st ON sc.sno = st.sno ***

WHERE

sc.score < 60;

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

select c#,count(S#) from sc group by C#;

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

select SC.S#,Student.Sname,count(C#) AS 选课数

from SC ,Student

where SC.S#=Student.S# group by SC.S# ,Student.Sname having count(C#)=1;

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

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

group_concat(case when isfull(score ,0) >=85 then sname end) as '优秀'

,group_concat(case when isfull(score ,0) between 70 and 85 then sname end ) as '良好'

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

select Sname,SC.S# ,avg(score)

from Student,SC

where Student.S#=SC.S# group by SC.S#,Sname having avg(score)>85;

你可能感兴趣的:(MySQL-第一阶段测试)