2025年MySQL面试题

MySQL面试题遭人嫌弃的培训班 IT 人员 由于 IT 软件行业对人才的需求很大 很多传统行业也纷纷创办 互联网 项目 加上 App 开发热潮 微信公众平台也催生了更多的就业岗位 于是 IT 从业人员的薪水也随之水涨船高 同时 IT 培训班也随雨后春笋般涌出 一个个打出响亮的口号 0 基础入学 三个月包就业

大家好,我是讯享网,很高兴认识大家。

遭人嫌弃的培训班IT人员

由于 IT 软件行业对人才的需求很大,很多传统行业也纷纷创办“互联网+”项目,加上 App 开发热潮,微信公众平台也催生了更多的就业岗位。于是 IT 从业人员的薪水也随之水涨船高。同时 IT 培训班也随雨后春笋般涌出,一个个打出响亮的口号。

  • 0 基础入学,三个月包就业,学不会,不收学费
  • 轻轻松松学编程,月入过万不是梦
  • 先就业,后付款

对于迫切想改变自己境遇的人来说,这些口号无疑是很具诱惑力的。在培训机构的宣传下,好像软件开发行业是一个门槛低,收入高,只要几个月的培训就可以月入过万,实现人生理想的好职业。

可现实是越来越多的企业不想招,甚至明言不招培训班出来的学生。而不少培训班也会教学生隐瞒自己的培训经历,会教学生面试的技巧,包装简历,虚报学历和工作经历,把学生包装成一个具有两年项目开发经验的软件工程师,而且开价往往都不低。

#为什么会被嫌弃

培训班出身的学生被嫌弃的原因主要有以下几个:

  • 计算机基础知识极其薄弱,基本上只是会简单的业务逻辑,懂得基本的增删改查。
  • 自学能力弱,在短期培训过程中,接收的是填鸭式的教育,即使讲师的教学水平极高,学生极努力,也不可能在短时间内将这些知识消化,大多数只是一知半解,知道有这么个概念罢了,面试时也许可以做到应答自如,可实操能力极弱。而且习惯的是视频式的、类似于手把手教学的模式。对于新知识的自学能力很差,看文档的能力很弱
  • 开价高,心浮气躁。大多数参加培训的都不是学计算机专业的。有些甚至以前连电脑都没怎么用过,连打字都很慢。这些人之所以去培训,是因为在原行业混得不好,又听说 IT 行业工资高,才转行过去。有这种心态的人,做哪个行业都很难有成就,但别说在 IT 行业,要做好软件开发,专注、执着、认真是必备的素质。为钱而来的还是请退场吧。你们把因果关系颠倒了。不是 IT 行业高薪,而是因为专注于这个行业,才高薪。那些靠混的,凭借着互联网热潮上位的,是有可能混到一份不错的 offer,可不会长久。

#你弱,你还有理了

不否认,有些人虽然是培训班出身,但很优秀,可这个占比太小了。对于企业用人部门来说,他们不值得去为此而冒险,优秀的企业在招人时是很慎重的,招一个人的成本也是相当高,企业招一个人肯定会综合衡量利弊。尤其是软件开发行业,优秀与平庸的人相差太多了,效率上可能相差十倍以上

一个优秀的程序员写出诗一样的代码,一个平庸的写出的是屎一样的代码。不仅不可用,还会对整个项目起到污染,连累他人擦屁股。

换位思考,当你处于企业用人单位的角色,你也不会选择冒险去招培训班出身人的?宁愿多花时间,提高 offer 去招更有可能是靠谱的人。

#别以为自己真有两年经验

千万别相信讲师给你灌输的鬼话:“这几个月就已经让你们有两年的项目经验了”。复制代码,跟实际经验完全不同!那几个月,你学到的只是知识,只是最基础的知识,你并没有得到半点经验!经验是不可能靠他人传授的,因为自己经历过才算得上是经验!没有经历过项目 deadline,没有被莫名其妙的 bug 弄得焦头烂额,没有真正的团队合作经历,就靠那几个月复制讲师的代码,就说自己有两年的开发经验了。

#打铁还需自身硬

那么是不是培训班出身的人就没有机会了?当然不是,出身不好,起点差都不代表着前面的路就被堵死了。前面说了那么多嫌弃的话,主要是要让你认识到自己为什么会被嫌弃,而不是以受害者的心态自怨自艾(“受害者心态无济于事”)。

以下是对于真正想从事软件开发行业的人提供的建议:


讯享网

  • 认清自己的能力,不要骄狂自大;即使你真的很弱。不要妄自菲薄;因为每个人都是从弱小中成长的。认清自己的能力,是成长的第一步。
  • 证明自己的能力。程序员证明自己能力最简单的方式就是代码。“Talk is cheap, Show me the code”. 从现在开始,你就要养成输出知识的习惯,可以是写技术博客,也可以是构建个人网站,把这些作品展示出来,现在免费的展示平台那么多,你一定要长久地积累,这些就是你最好的简历
  • 忘记自己是从培训班出来的,把自己当成一个自学者。优秀的程序员都是野生的,培训班出来的是只是宠物,面试时不用提你培训的经历,虽然这并不丢人,但可能会带来偏见。只要你能展示你的作品,表现你的自学能力,而你自身的能力又过关,其实不管你是什么出身,都无关紧要

#总结

嫌弃的不是你的出身,而是你的综合素养!

总之,出身差,就靠实力,实力差,就靠态度。你之所以会被嫌弃,不是因为你来自培训班,而是因为你没有摆脱培训班,没有构建自己的知识体系。当然,这些积累是需要长时间的,所以慢慢来,只要你不是奔着钱来的,你总能找到工作,也总能得到成长


image.png

有错误请留言…

 -------- __@ __@ __@ __@ __~@ ----- _`\<,_ _`\<,_ _`\<,_ _`\<,_ _`\<,_ ---- (*)/ (*) (*)/ (*) (*)/ (*) (*)/ (*) (*)/ (*) 

讯享网
一位不知道名字的优秀大佬整理的试题答案

https://www.cnblogs.com/xiejincheng/p/7071479.html

试题参考简书好友 国王12

https://www.jianshu.com/p/eb70f9e020cf

一、简答题

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

讯享网使用的是5.7版本,小版本是5.7.20,我刚进到公司时数据库就是5.7.20版本,此版本是在17年九月份更新的 还有5.6.38 5.6.40也稍作过了解 GA时间都是选择6-12个月的版本的偶数版 

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

RDBMS关系型: Oracle ,MySQL ,MSSQL(微软),PG NoSQL非关系型:Redis,Mongo,ES NewSQL分布式型:pingCap公司的一套系统TiDB,Google开发的Spanner,阿里巴巴开发的OceanBase,阿里云开发的PolarDB 

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

讯享网1.规划硬件环境,版本,网络,存储 2.创建软件目录和数据目录 3.解压二进制包后配置环境变量并生效 4.卸载mariadb,安装libaio-devel 5.二进制安装mysql,指定软件安装目录和数据目录 6.书写配置文件后启动mysql 

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

netstat -lnp|grep mysqld ps -ef|grep mysqld 

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

讯享网Oracle MySQL MariaDB PerconaDB 云数据库有RDS MySQL 腾讯DB等 

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

1.首先经过连接层,提供连接协议(sokcet tcp/ip),验证用户密码主机IP和端口号后提供链接线程。 2.然后到SQL层,进行约束规定(语法检查和SQL_MODE检查),再进行语义检查和权限检查后,生成解析树 3.最后通过存储引擎层,根据SQL层执行的结果从磁盘拿数据,再讲16进制的数据转换成表,最后通过连接层的专用线程返回给用户 

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

讯享网CentOS7中 systemd启动 <systemctl start mysql.service> CentOS6中 sys-V启动 </etc/init.d/mysqld start> 

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

1.数据库的启动先读取指定的用户 2.读取软件存放的路径 3.读取生成的套接字文件 4.客户端的登录,读取生成的套接字文件 

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

讯享网初始化配置文件,一旦使用<--defaults-file>,默认配置就不会生效了 

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

1.先关闭数据库 /etc/init.d/mysqld stop 2.将数据库启动到无验证模式 mysqld_safe --skip-grant-tables --skip-networking & 3.进入后刷新 flush privileges; 4.修改密码 alter user root@'localhost' identified by '123'; 5.退出重启数据库为正常模式 /etc/init.d/mysqld restart 6.测试新密码是否可以登录 mysql -uroot -p123 

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

讯享网DDL 数据定义语言 DCL 数据控制语言 DML 数据操作语言 DQL 数据查询语言 

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

https://www.cnblogs.com/s-b-b/p/8334593.html

1.聚集索引:指索引项的排序方式和表中数据记录排序方式一致的索引,每张表只能有一个聚集索引,聚集索引的叶子节点存储了整个行数据。 2.辅助索引:辅助索引中索引的逻辑顺序与磁盘上行的物理存储顺序不同,一个表中可以拥有多个非聚集索引。 

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

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

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

讯享网 

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

 

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

讯享网 

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

1.查看配置文件中指定的软件路径,数据路径和套接字文件路径是否指定正确 2. 

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

https://blog.csdn.net/weixin_/article/details/

讯享网1、普通索引 2、唯一索引 3、全文索引 4、单列索引 5、多列索引 6、空间索引 

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

1.MyISAM是Mysql的默认存储引擎,当create创建新表时,未指定新表的存储引擎时,默认使用Myisam。 2.InnoDB存储引擎 

18.InnoDB存储引擎核心特性

讯享网InnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比Myisam的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。 

二、操作题

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

create user oldboyl@'10.0.0.0/255.255.254.0'; 

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

讯享网GRANT SELECT,INSERT,UPDATE,DELETE ON wordpress.* TO wordpress@'172.16.1.%' IDENTIFIED BY '123'; 

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

[mysqld] user=mysql basedir=/application/mysql datadir=/data/3306/data socket=/tmp/mysql.sock [mysql] socket=/tmp/mysql.sock prompt=MySQL [\\d]> 

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

讯享网mysql -uoldboy -p -h10.0.0.51 -P 3306 

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

SHOW VARIABLES LIKE '%character%'; 

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

讯享网CREATE DATABASE oldboy CHARSET GBK; 

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

NOT NULL修饰符: 指定该字段是否可以为空,默认情指定字段为NULL,如果一个字段指定为NOT NULL则不允许向该字段插入空值 DEFAULT修饰符: 为字段设定一个默认值,当插入记录时是空值时,会自动为您设置上该字段的默认值 AUTO_INCREMENT修饰符: 只适用于INT字段,该自动为该字段生成一个数(每次在上一次生成的数值上面加1) 

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

讯享网create user 'oldboy'@'10.0.0.%'; GRANT SELECT,INSERT,UPDATE,DELETE ON oldboy.* TO oldboy@'10.0.0.%'; 

9. 收回oldboy用户的drop权限

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

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

讯享网show grants for oldboy@'10.0.0.%'; 

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

show tables; desc city; show create table city; #查看表内容 

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

讯享网 

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

 

14.查询名字为oldboy的记录

讯享网 

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

 

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

讯享网 

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

show status like 'handler_read_key'; 

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

讯享网drop table school; 表定义和数据全部删除 truncate table xs; 清空表的区,立即释放磁盘空间,数据清空,表定义保留 

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

 

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

讯享网 

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

 

22.删除Name,shouji列的索引

讯享网 

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

 

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

讯享网 

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

 

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

讯享网 

27.Select查询语句加强练习

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

 

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

讯享网 

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

 

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

讯享网 

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

 

29. SQL综合练习

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

讯享网 

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

 

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

讯享网 

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

 

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

讯享网 

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

 

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

讯享网 

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

 

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

讯享网 
小讯
上一篇 2025-01-13 19:26
下一篇 2025-03-29 20:25

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/61730.html