2019-06-17 MySQL测试题(一)

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

oracle mysql 5.6.38
oracle mysql 5.7.20
GA时间:2017-9-13

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

ODBMS:oracle mysql mssql postgresql
NoSQL:memcached mongodb redis

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

下载解压
创建mysql用户
创建数据文件夹并设置权限
设置环境变量并source:echo ‘export PATH=$PATH:/usr/local/mysql/bin‘>>/etc/profile;source /etc/profile
初始化数据库:mysqld --initialize-insecure  --user=mysql --datadir=/data/mysql --basedir=/usr/bin/mysql
生成配置文件:/etc/my.cnf
启动服务

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

进程:ps -ef|grep mysqld
端口:netstat -lnutp|grep 3306;ss -lnutp|grep 3306
直接mysql 登陆测试

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

oracle mysql:      最新版本8.0 稳定版本 5.7
percona mysql:  最新版本8.0 稳定版本 5.7
mariadb:            最新版本10.4 稳定版本 10.3

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

连接层:
    提供连接协议,验证,专用连接线程
SQL层
    语法,语义,权限,解析,优化,执行,查询缓存,日志记录
存储引擎层
    相当于Linux文件系统,例如:InnoDB提供了事务,CSR,热备,MVCC,行级锁等

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

sys-v:mysql.server--->mysqld_safe---->mysqld
systemd: mysqld --defaults-file
mysqld_safe
mysqld

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

[[email protected] ~]# mysqld --help --verbose|grep my.cnf
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf 

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

自定义mysql配置文件并在后台启动mysql

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

[[email protected] ~]# mysqld_safe --skip-grant-tables --skip-networking
--skip-grant-tables: 关闭连接层的验证功能
--skip-networking:关闭TCP/IP协议

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

DDL
DCL
DML
DQL

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

辅助索引,叶子节点只存储,有序的某个列的所有值
聚集索引,存储的是整行数据
辅助索引一般是配合聚集索引使用,通过辅助所用找到主键值,然后通过聚集索引找到数据行,减少了回表查询带来的硬盘IO

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

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

![](https://s1.51cto.com/images/blog/201906/17/ddacb4adefc3f67f6b766453b41a925b.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)
image.png
结果:type--all;Extra--filesort;
1. countrycode没有走索引,有可能是没建立索引,或者是索引失效
2. 出现了filesort文件排序, orderby条件也没走索引

建议:
1. 如果没有索引导致,建立联合索引(countrycode,population)
2. 如果是索引失效,删除索引重建
简述出现以下结果的可能原因
![](https://s1.51cto.com/images/blog/201906/17/3b002b14ce2948738950877c85e2bc8e.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)

应该是 telnum列是字符串类型,不加引号导致出现了隐式转换,需要进一步判断数据类型,建议加上单引号.
请简述,影响索引树高度的因素?
数据量级:分表分库分布式
索引键值太长:前缀索引
数据类型:char varchar选择,enum,选择合理的数据类型

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

数据量级:分表分库分布式
索引键值太长:前缀索引
数据类型:char varchar选择,enum,选择合理的数据类型

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

先看服务有没有启动;
再看配置文件中sock文件设置,ls查看有无文件
再然后看日志;
如果没有日志,使用mysqld直接测试启动

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

B树
HASH
R树

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

InnoDB,MyIAM,CSV,TokuDB, Percona-XtraDB

18.InnoDB存储引擎核心特性

事务,CSR,MVCC,行级锁,热备,外键

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

create user [email protected]‘10.0.0.%/255.255.255.0‘ identified by ‘123‘;
SELECT DISTINCT user,host FROM mysql.user;
user   | host                   |
+--------+------------------------+
| oldboy | 10.0.0.%/255.255.255.0
...
2.创建应用用户:wordpress能通过172.16.1.0/24网段任意地址登录操作wordpress库下的所有表

create user [email protected]‘172.16.1.%/255.255.255.0‘ identified by ‘123‘;
grant all on wordpress.* to [email protected]‘172.16.1.%/255.255.255.0‘;
grant all select update insert delete wordpress.* to [email protected]‘172.16.1.%/255.255.255.0‘; 

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 -h 10.0.0.30 -P3306(端口可省略)

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

show语句
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:自动增长

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

grant all on oldboy.* to  [email protected]‘10.0.0.%‘ identified by ‘123‘;

9.收回oldboy用户的drop权限

revoke drop on oldboy.* from  [email protected]‘10.0.0.%‘;

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

show grants for [email protected]‘10.0.0.%‘;

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

desc stu;
show create table stu;
12.插入一条数据“1,oldboy”

insert into stu values(1,‘oldboy‘);

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

insert into stu values(2,‘老男孩‘);
insert into stu values(3,‘oldboyedu‘);
14.查询名字为oldboy的记录

select * from t1 where name=‘oldboy‘;
查看数据库中所有引擎的类型
show engines;
16.查看数据库关于日志的参数配置

show variables like ‘%log%‘;
17.查看handler_read_key当前的状态信息

show status like ‘handler_read_key‘;

18.delete和truncate区别

delete :逻辑逐条删除数据行
trucate:物理删除表段中的所有数据页

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

create table test (
id int not null  primary key comment ‘学号‘,
name varchar(64) not null comment ‘姓名‘,
telnum char(11) not null comment ‘手机号‘
)engine InnoDB Charset Utf8 comment ‘学生表‘;
alter table test add index idx_name(name);

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

alter table add index idx_tel(telnum(8));

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

desc test;
show index from test

22.删除Name,shouji列的索引

alter table test drop index idx_name ;
alter table test drop index idx_tel;

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

alter table test add index idx_n_t(name(6),telnum(8));

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

alter table test add unique index idx_tel(telnum);

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

select name,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,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 countrycode,count(name)
 from city
group by 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 -p123 ",table_schema," ",table_name," >/bak/",table_schema,"_",table_name,".sql")
FROM information_schema.TABLES

29.SQL综合练习

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

select student_id,avg(num) from score group by student_id having avg(num) > 60
2). 查询所有同学的学号、姓名、选课数、总成绩;

select score.student_id,sum(score.num),count(score.student_id),student.sname
from score left join student
on score.student_id = student.sid
group by score.student_id
3). 查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分

select course_id, max(num) as max_num, min(num) as min_num from score group by course_id;
4).统计各位老师,所教课程的及格率(case)

count(case  when isfull(socre,0)>=60 then 1 end)/count(*)
group by 学科
5).查询每门课程被选修的学生数

 select course_id, count(student_id) from score group by course_id;
6).查询出只选修了一门课程的全部学生的学号和姓名

select student.sid, student.sname, count(course_id)
from score left join student
on score.student_id  = student.sid
group by course_id having count(course_id)  = 1
7).查询选修课程门数超过1门的学生信息

select * from score group by student_id having count(student_id) > 1
8).统计每门课程:优秀(85分以上),良好(70-85),一般(60-70),不及格(小于60)的学生列表(case)

SELECT t1.c#,t2.cname,
       SUM(CASE WHEN t1.score > 85 AND t1.score <= 100 THEN 1 ELSE 0 END) AS 优秀人数,
       SUM(CASE WHEN t1.score > 70 AND t1.score <= 85 THEN 1 ELSE 0 END)  AS 良好人数,
       SUM(CASE WHEN t1.score > 60 AND t1.score <= 70 THEN 1 ELSE 0 END)  AS 一般人数,
       SUM(CASE WHEN t1.score <= 60 THEN 1 ELSE 0 END)                    AS 刚及格人数
FROM sc t1
INNER JOIN course t2
  ON t1.c# = t2.c#
GROUP BY t1.c#,t2.cname
9).查询平均成绩大于85的所有学生的学号、姓名和平均成绩

select student_id,sname, avg(if(isnull(score,0) ,>85))
from score left join student
on score.student_id = student.sid
group by student_id;

SELECT student_id, sname,AVG(score.score) AS avg_score
from score left join student
ON score.student_id = student.sid
GROUP BY student_id
HAVING AVG(score.score) > 85

原文地址:https://blog.51cto.com/9447803/2409932

时间: 2024-11-09 04:46:50

2019-06-17 MySQL测试题(一)的相关文章

解题报告 smoj 2019初二创新班(2019.3.17)

目录 解题报告 smoj 2019初二创新班(2019.3.17) T1:找玩具 题目描述 题意转化 分析 代码 优化(代码复杂度) T2:闯关游戏 题目描述 分析 代码 T3:子数组有主元素 题目描述 分析 代码(\(O(nm\log n)\)) 优化 代码(\(O(nm)\)) 解题报告 smoj 2019初二创新班(2019.3.17) 时间:2019.3.21 T1:找玩具 题目描述 在游戏开始之前,游戏大师在房间的某些地方隐藏了N个玩具.玩具编号为1到N.您的任务是尽可能多地找到这些玩

开荒日-2019/06/19

2019/06/19,毕业两年之际,个人原因来到了台州,这个对程序员来说不是很友好的地方,技术提升遇到了阻碍,想要从项目中学习东西但是收获甚微,还好现在的工作时间比较宽裕,让我有不少可以自由支配的时间,也算是到了工作的舒适区吧,但是此刻心里还是挺着急的,压力来源于对技术能力的渴望,却少有可以锻炼的机会.所以决定自己动手丰衣足食,打算开发一个自己的小产品,考虑了几天,打算搭建一个基础版本的OA平台(我现在的工作就是对一套OA系统进行二次开发),把开发过程中遇到的问题和新学的技术记录在博文中,以便以

2019.12.17 面向对象习题

/** * TimeTraveler.java * com.DuiXiang * * Function: TODO * * ver date author * ────────────────────────────────── * 2019年12月17日 17671 * * Copyright (c) 2019, TNT All Rights Reserved.*/ package com.DuiXiang; /** * ClassName:TimeTraveler Function: TOD

第06章 mysql 运算符

2015-10-24 目录 参考资料 [1] 唐汉明.深入浅出MySQL 数据库开发.优化与管理维护(第2版)[M].北京:人民邮电出版社,2014 [2] Schwartz.高性能MySQL(第3版)[M].北京:电子工业出版社,2013 [3] 范德兰斯.MySQL开发者SQL权威指南 [M].北京:机械工业出版社,2008 [4] Forta.MySQL必知必会 [M].北京:人民邮电出版社,2009 [5] 12.3 Operators [6] MySQL中的运算符使用实例展示 [7] 

2019 1 17 赵松儒

1.函数的定义:返回值类型 函数名(函数列表) 2.函数的声明:返回值类型 函数名(参数类型): 3.函数的调用:变量 = 函数名(参数的值)(在函数有返回值的时候)     注意:若函数无返回值,返回值类型为void 4.函数的传参是从右至左的 如:printf("a:%d, b:%d, c:%d", a, b, c);先传c,再传b,再传a 5.变量分为:局部变量 全局变量    局部变量:在函数内定义              生存周期和作用域:从定义开始到函数结束      

06、MySQL—列类型

1.整数类型 I.有符号整型 (1) Tinyint:单字节整形,系统采用一个字节来保存的整形:一个字节 = 8位,最大能表示的数值是0-255. (2) Smallint:双字节整形,系统采用两个字节来保存的整形:能表示0-65535之间 (3) Mediumint:三字节整形,采用三个字节来保存数据 (4) Int:整形(标准整形),采用四个字节来保存数据 (5) Bigint:大整形,采用八个字节来保存数据. ① 创建数据表 ② 插入合理数据 ③ 插入错误数据(超出对应的数据范围) 错误原

2019年17道高频React面试题及详解

以下面试题来源于github项目前端面试指南,那里有超过200道高频前端面试题及答案,目前拥有1400star. 为什么选择使用框架而不是原生?框架的好处: 组件化: 其中以 React 的组件化最为彻底,甚至可以到函数级别的原子组件,高度的组件化可以是我们的工程易于维护.易于组合拓展.天然分层: JQuery 时代的代码大部分情况下是面条代码,耦合严重,现代框架不管是 MVC.MVP还是MVVM 模式都能帮助我们进行分层,代码解耦更易于读写.生态: 现在主流前端框架都自带生态,不管是数据流管理

2019/9/17 校内练习赛 解题报告

比赛详情 本次练习赛已收录至2019/9/22 本周总结 tree 给定一棵无根树,求使得所有节点深度和最大的根节点. 思路 考虑先令\(1\)为根,\(tot\)为此时所有节点深度和,预处理\(size(x)\)表示\(x\)子树的大小.设\(u\)为\(1\)的某个儿子,显然从\(1\)走到\(u\)时,有: \[tot=tot+(n-size[u])-size[u]\] 将结论推广到所有节点,扫描整棵树得到答案,时间复杂度\(O(n)\). 代码 #include<bits/stdc++.

2019.10.15 MySQL 事务介绍及操作演示

一.数据库事务的概念 事务是一种机制.一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这一组数据库命令要么都执行,要么不都执行. 事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时,事务是最小的控制单元. 事务适用于多用户同时操作的数据库系统的场景,如银行.保险公司及证券交易系统等等.通过事务的完整性以保证数据的一致性. 二.事务的ACID特点事务具有四个属性:ACID原子性(Atomicity)一致性(Consistency)隔高