掌握了这35道MySQL技术问题,面试还有何惧?
yuyutoo 2024-12-15 17:41 6 浏览 0 评论
1 MySQL 简介
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一。
2 MySQL的50道常见面试题总结
2.1 Mysql中的锁有哪些?
Mysql存储引擎MyISAM支持表锁,Mysql存储引擎InnoDB支持表锁和行锁(默认为行锁)
表锁和行锁优缺点:
表锁:开销小,加锁快,不会出现死锁。锁定粒度大,发生锁冲突的概率最高,并发量最低。
行锁:开销大,加锁慢,会出现死锁。锁力度小,发生锁冲突的概率小,并发度最高。
2.2 怎么操作容易损坏MYSQL数据表?
突然断电导致服务器关机
没先停用mysql 服务,二十强制关机服务器。
以上这种类似情况,都会而导致数据库数据文件损坏。
2.3 用MYSQL记录钱的字段,用什么类型最好?
如果字段和钱有关的用NUMERIC和DECIMAL类型最好。NUMERIC和DECIMAL被用于保存值,该值的准确精度是极其重要的值。
因为DECIMAL和NUMERIC的值是作为字符串存储,因此才能保存更精准的小数。
2.4 MYSQL支持事务吗?有哪些事务支持?
缺省情况下,mysql是不支持事务的。此时是autocommit模式,所有更新操作都是即时提交。
如果MYSQL用的InnoDB Tables 或 BDB tables,则可用事务处理;当然如果设置 SET AUTOCOMMIT=0 也就不使用事务操作了。
2.5 MYSQL的访问控制列表是什么意思?
ACL(访问控制列表)是与对象关联的权限列表。这个列表是Mysql服务器安全模型的基础,它有助于排除用户无法连接的问题。
2.6 通用SQL函数是什么?
CONCAT(A, B)
连接两个字符串值以创建单个字符串输出。通常用于将两个或多个字段合并为一个字段。
DATEDIFF(A,B)
确定两个日期之间的差异,通常用于计算年龄。
SUBTIMES(A,B)
确定两者之间的差异。
FROMDAYS(INT)
将整数天数转换为日期值。
FORMAT(X, D)
格式化数字X到D有效数字。
NOW()
将当前日期和时间作为一个值返回。
MONTH(),DAY(),YEAR(),WEEK(),WEEKDAY()
从日期值中提取给定数据。
CURRDATE(), CURRTIME()
返回当前日期或时间。
HOUR(),MINUTE(),SECOND()
从时间值中提取给定数据。
2.7 MYSQL非标准字符串有哪些?
TINYTEXT
TEXT
MEDIUMTEXT
LONGTEXT
2.8 Mysql表最多允许多少个触发器?
BEFORE INSERT
AFTER INSERT
BEFORE UPDATE
AFTER UPDATE
BEFORE DELETE
AFTER DELETE
2.9 Mysql中CREATE语句可以创建哪些对象?
DATABASE
EVENT
FUNCTION
INDEX
PROCEDURE
TABLE
TRIGGER
USER
VIEW
2.9 Mysql中NOW()和CURRENT_DATE()区别是啥?
NOW()函数用来取当前时间(包含年、月、日、时、分、秒)。
CURRENT_DATE()只取当前年、月、日。
2.10 Mysql中一张表最多创建多少个索引?
表最多只能创建16个索引。
2.11 Mysql中取前50行数据?
SELECT*FROM tableLIMIT 0,50;
2.12 Mysql中如何输入字符为十六进制数字?
MYSQL中输入带有单引号的十六进制数字和前缀(X),或者只用(Ox)前缀输入十六进制数字。
2.13 怎么优化Mysql中的DISTINCT?
DISTINCT在所有列上转换为GROUP BY,并与ORDER BY子句结合使用。
SELECT DISTINCT t1.a FROM t1,t2 where t1.a=t2.a;
2.14 Mysql中ISAM是什么?
ISAM简称为索引顺序访问方法。
2.15 Mysql中有哪些存储引擎?
MyISAM
Heap
Merge
INNODB
ISAM
MyISAM是Mysql的默认存储引擎。
2.16 MYSQL中加入现在有一张表,ID为自增主键,当insert了20条数据之后,删除了第18、19、20条数据。然后Mysql重启,再insert一条数据,这条数据的ID是21还是18 ?
(1)如果是MylSAM引擎,此时ID为21
因为MyISAM表会把自增主键的最大ID记录到数据文件里,重启MySQL自增主键的最大ID也不会丢失。
(2)如果表的类型是InnoDB,那么是18.
InnoDB表只是把自增主键的最大ID记录到内存中,所以重启数据库或者是对表进行OPTIMIZE操作,都程序之心会导致最大ID丢失.
2.17 Mysql的优势有哪些?
Mysql是开源、免费的。
Mysql是便携式的。
使用Mysql查询浏览器支持管理。
2.18 Mysql中FLOAT和DOUBLE怎么区分他们?
浮点数以8位精度存储在FLOAT中,并且有四个字节。
浮点数存储在DOUBLE中,精度为18位,有八个字节。
2.19 Mysql中CHAR_LENGTH和LENGTH怎么区分他们?
CHAR_LENGTH是字符数,而LENGTH是字节数。
Latin字符的这两个数据是相同的,但是对于Unicode和其他编码,它们是不同的。
2.20 Mysql中InnoDB支持的四种事务隔离级别及区别?
四个隔离级别为:
read uncommited :读到未提交数据
read committed:脏读,不可重复读
repeatable read:可重读
serializable :串行事物
四种事务隔离级别区别:
2.21 Mysql中枚举的用法是?
ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用。
Create table size(name ENUM('Smail,'Medium','Large');
2.22 Mysql中CHAR和VARCHAR的区别?
CHAR和VARCHAR类型在存储和检索方面有所不同
CHAR列长度固定为创建表时声明的长度,长度值范围是1到255
当存储CHAR值时,长度不够时用空格填充,查询时删除填充空格。
2.23 Mysql中列的字符串类型可以有哪些?
SET
BLOB
ENUM
CHAR
TEXT
VARCHAR
2.24 Mysql中使用什么存储引擎?
存储引擎称为表类型,数据使用各种技术存储在文件中。
技术存储包含:
Storage mechanism
Locking levels
Indexing
Capabilities and functions.
2.25 Mysql中驱动程序有哪些?
PHP驱动程序
JDBC驱动程序
ODBC驱动程序
CWRAPPER
PYTHON驱动程序
PERL驱动程序
RUBY驱动程序
CAP11PHP驱动程序
Ado.net5.mxj
2.26 Mysql中MyISAM表格是存储在哪里的?有哪些存储格式?
MyISAM表格存储在磁盘上。
存储格式为:
·“.frm”文件存储表定义
·数据文件具有“.MYD”(MYData)扩展名
索引文件具有“.MYI”(MYIndex)扩展名
2.27 Mysql中如何运行批量处理模式?
mysql;
mysql mysql.out
2.27 Mysql中mysql_fetch_array和mysql_fetch_object的区别是什么?
mysql_fetch_array()
将结果行作为关联数组或来自数据库的常规数组返回。
mysql_fetch_object
从数据库返回结果行作为对象。
2.28 Mysql中BLOB和TEXT有什么区别?
BLOB是一个二进制对象,可以容纳可变数量的数据。
有四种类型的BLOB:
TINYBLOB
BLOB
MEDIUMBLOB和
LONGBLOB
TEXT不区分大小写的。
四种TEXT类型:
TINYTEXT
TEXT
MEDIUMTEXT和
LONGTEXT
它们对应于四种BLOB类型,并具有相同的最大长度和存储要求。
BLOB和TEXT区别主要就是大小写区分。
2.29 Mysql中LIKE和REGEXP操作有什么区别?
LIKE和REGEXP运算符用于表示^和%。
使用示例:
SELECT * FROM employee WHERE emp_name REGEXP "^b";
SELECT * FROM employee WHERE emp_name LIKE "%b";
2.30 Mysql中查询是否区分大小写?
不区分。
2.31 Mysql中查询受查询影响的行数?
SELECT COUNT(user_id)FROM users;
2.32 Mysql中LIKE声明中的%和_是什么意思?
%对应于0个或更多字符,_只是LIKE语句中的一个字符。
2.33 Mysql中表有一列定义为TIMESTAMP,将发生什么?
每当行被更改时,时间戳字段将获取当前时间戳。
2.34 Mysql中服务器性能分析的方法命令有哪些?
Show status
一些值的监控的变量值:
Bytesreceived和Bytessent
和服务器之间来往的流量。
Com*服务器正在执行的命令
Created*在查询执行期限间创建的临时表和文件。
Handler*存储引警操作。
Select不同类型的联接执行计划。
Sort*几种排序信息。
·Show session status like 'Select;
·Show profiles
SET profiling=1
Show profiles)G
Show profile;
2.35 怎样才能找出最后一次插入时分配了哪个自动增量?
LAST_INSERT_ID将返回由Auto_increment分配的最后一个值,并且不需要指定表名称。
相关推荐
- 当 Linux 根分区 (/) 已满时如何释放空间?
-
根分区(/)是Linux文件系统的核心,包含操作系统核心文件、配置文件、日志文件、缓存和用户数据等。当根分区满载时,系统可能出现无法写入新文件、应用程序崩溃甚至无法启动的情况。常见原因包括:...
- 玩转 Linux 之:磁盘分区、挂载知多少?
-
今天来聊聊linux下磁盘分区、挂载的问题,篇幅所限,不会聊的太底层,纯当科普!!1、Linux分区简介1.1主分区vs扩展分区硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两...
- Linux 文件搜索神器 find 实战详解,建议收藏
-
在Linux系统使用中,作为一个管理员,我希望能查找系统中所有的大小超过200M文件,查看近7天系统中哪些文件被修改过,找出所有子目录中的可执行文件,这些任务需求...
- Linux 操作系统磁盘操作(linux 磁盘命令)
-
一、文档介绍本文档描述Linux操作系统下多种场景下的磁盘操作情况。二、名词解释...
- Win10新版19603推送:一键清理磁盘空间、首次集成Linux文件管理器
-
继上周四的Build19592后,微软今晨面向快速通道的Insider会员推送Windows10新预览版,操作系统版本号Build19603。除了一些常规修复,本次更新还带了不少新功能,一起来了...
- Android 16允许Linux终端使用手机全部存储空间
-
IT之家4月20日消息,谷歌Pixel手机正朝着成为强大便携式计算设备的目标迈进。2025年3月的更新中,Linux终端应用的推出为这一转变奠定了重要基础。该应用允许兼容的安卓设备...
- Linux 系统管理大容量磁盘(2TB+)操作指南
-
对于容量超过2TB的磁盘,传统MBR分区表的32位寻址机制存在限制(最大支持2.2TB)。需采用GPT(GUIDPartitionTable)分区方案,其支持64位寻址,理论上限为9.4ZB(9....
- Linux 服务器上查看磁盘类型的方法
-
方法1:使用lsblk命令lsblk输出说明:TYPE列显示设备类型,如disk(物理磁盘)、part(分区)、rom(只读存储)等。...
- ESXI7虚机上的Ubuntu Linux 22.04 LVM空间扩容操作记录
-
本人在实际的使用中经常遇到Vmware上安装的Linux虚机的LVM扩容情况,最终实现lv的扩容,大多数情况因为虚机都是有备用或者可停机的情况,一般情况下通过添加一块物理盘再加入vg,然后扩容lv来实...
- 5.4K Star很容易!Windows读取Linux磁盘格式工具
-
[开源日记],分享10k+Star的优质开源项目...
- Linux 文件系统监控:用脚本自动化磁盘空间管理
-
在Linux系统中,文件系统监控是一项非常重要的任务,它可以帮助我们及时发现磁盘空间不足的问题,避免因磁盘满而导致的系统服务不可用。通过编写脚本自动化磁盘空间管理,我们可以更加高效地处理这一问题。下面...
- Linux磁盘管理LVM实战(linux实验磁盘管理)
-
LVM(逻辑卷管理器,LogicalVolumeManager)是一种在Linux系统中用于灵活管理磁盘空间的技术,通过将物理磁盘抽象为逻辑卷,实现动态调整存储容量、跨磁盘扩展等功能。本章节...
- Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!
-
Linux查看文件大小:ls和du为何结果不同?一文讲透原理!在Linux运维中,查看文件大小是日常高频操作。但你是否遇到过以下困惑?...
- 使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量
-
在Linux系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用...
- Linux磁盘爆满紧急救援指南:5步清理释放50GB+小白也能轻松搞定
-
“服务器卡死?网站崩溃?当Linux系统弹出‘Nospaceleft’的红色警报,别慌!本文手把手教你从‘删库到跑路’进阶为‘磁盘清理大师’,5个关键步骤+30条救命命令,快速释放磁盘空间,拯救你...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)