首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
静静202306152219706
成都东软学院 数据采集
发布于四川
关注
已关注
取消关注
@蓦_然:
MySQL面试题(三)
27、索引的底层实现原理和优化 B+树, 经过优化的B+树主 要是在所有的叶子结点中增加了指向下一个叶子节点的指针, 因此InnoDB 建 议 为大部分表使用默认自增的主键作为主索引。 28、什么情况下设置了索引但无法使用 1、 以 “ % ” 开 头 的 LIKE 语 句 , 模 糊 匹 配 2 、 OR 语 句 前 后 没 有 同 时 使 用 索 引 3 、数 据 类 型 出 现 隐式转化(如 varchar 不 加 单 引 号 的 话 可 能 会 自 动 转 换 为 int 型 ) 29、实践中如何优化 MySQL 最好是按照以下顺序优化: 1 、 SQL 语句 及索 引的 优化 2、数据库表结构的优化 3、系 统配 置的 优化 4、硬件的优化 30、优化数据库的方法 1、选取 最适 用的 字段 属性 ,尽可 能减 少定 义字 段宽 度 ,尽量把字段设置NOTNULL,例如’省份 ’ 、 ’ 性别 ’最好 适用ENUM 2、使用连接(JOIN)来代 替子 查询 3、适用联合(UNION)来代 替手 动创 建的 临时 表 4、事务处理 5、锁 定表 、优 化事 务处 理 6、适用外键, 优化锁定表 7、建立索引 8、优 化查 询语 句 31、简单描述 MySQL 中,索引,主键,唯一索引,联合索引的区别,对数据库的性能有什么影响(从读写两方面) 索引是一种特殊的文件(InnoDB 数据表上的索引是表空间的一个组成部分), 它们包含着对数据表里所有记录的引用指针。 普通 索引(由关 键字 KEY 或INDEX 定义的索引)的唯 一任 务是 加快 对数 据的 访问 速 度。 普通索引允许被索引的数据列包含重复的值。 如果能确定某 个数据列将只包含彼 此各 不相同的值, 在为这个数据列创建索引的时候就应该用关键字UNIQUE 把它 定义为一个唯一索引。 也就是说, 唯一索引可以保证数据记录的唯一性。 主键, 是一种特殊的唯一索引, 在一张表 中只能定义一个主键索引, 主键用于唯 一标 识一条记录, 使用关键字 PRIMARY KEY 来创建。 索引可以覆盖多个数据列,如像INDEX(columnA, columnB)索引 ,这就 是联 合索 引。 索引可以极大的提高数据的查询速度, 但是会降低插入、删除、 更新表的速度, 因为在执行这些写 操作时, 还要操作索引文件。 32、数据库中的事务是什么? 事务 (transaction) 是 作为 一个 单元 的一 组有 序的 数据 库操 作。 如果 组中 的所 有操作都成功, 则认为事务成功, 即使只有一个操作失败, 事务也不成功。 如果所有操作完成, 事务则提交, 其修改将作用于所有其他数据库进程。如果一个操作失败, 则事务将回滚, 该事务所有操作的影响都将取消 。 事务特性: 1、原子性: 即不可分割性, 事务要么全部被执行, 要么就全部不被执行。 2 、 一致 性或 可串 性 。 事务 的执 行使 得数 据库 从一 种正 确状 态转 换成另一种正确状 态 3 、 隔离 性 。 在事 务正确提交之前, 不允许把该事务对数据的任何改变提供给任何 其他事务, 4 、 持久性。 事务正确提交后, 其结果将永久保存在数据库中, 即使在事务提交后 有了其他故障, 事务的处理结果也会得到保存。 或者 这样理解: 事务就是被绑定在一起作为 一个逻辑工作单元的SQL 语句分组, 如果任何一个语 句操作失败那么整个操作就被失败, 以后操作就会回滚到操作前状态, 或者是上 有个节点。为了确保要么执行, 要么不执行, 就可以使用事务。 要将有组语句作为事务考虑, 就需要通过ACID 测试 , 即 原子 性, 一致 性, 隔离 性和 持久 性。 33、SQL 注入漏洞产生的原因?如何防止? SQL 注入产生的原 因: 程序开发过程中不注意规范书写sql 语句和对特殊字符进 行过滤,导致客户端可以通过全局变量POST 和GET 提交一些sql 语句正常执行。 防止SQL 注入的方式: 开启配置文件中的magic_quotes_ gpc 和 magic_quotes_ runtime 设置 执行sql 语句时使用addslashes 进行sql 语句转换 Sql 语句书写尽量不要省略双引号和单引号。 过滤掉sql 语句中的一些关键词: update 、 insert 、 delete 、 select 、 * 。 提高数据库表和字段的命名技巧, 对一些重要的字段根据程序的特点命名, 取不 易被猜到的。 34、为表中得字段选择合适得数据类型 字段类型优先级: 整形 >date,time>enum,char>varchar>blob,text 优先考虑数字类型, 其次是日期或者二进制类型, 最后是字符串类型, 同级别得 数据类型, 应该优先选择占用空间小 的数据类型 35、存储时期 Datatime:以 YYYY - MM - DD HH:MM:SS 格式存储时期时间, 精确到秒, 占用8 个字 节得存储空间, datatime 类型与时区无关 Timestamp:以时间戳格式存储,占用4 个字 节 ,范围 小 1970 - 1 - 1 到 2038 - 1 - 19, 显示依赖于所指定得时区, 默认在第一个列行的数据修改时可以自动得修改 timestamp 列得值 Date: (生 日) 占用 得字 节数 比使 用字 符串 .datatime. int 储存要少, 使用date 只 需要3 个字 节, 存储 日期月份, 还可以利用日期时间函数进行日期间得计算 Time:存储 时间 部分 得数 据 注意 :不要 使用 字符 串类 型来 存储 日期 时间 数据 (通常 比字 符串 占用 得储 存空 间小 , 在进行查找过滤可以利用日期得函数) 使用int 存储日期时间不如使用timestamp 类型 36、对于关系型数据库而言,索引是相当重要的概念,请回答有关索引的几个问题: 1、 索 引 的 目 的 是 什 么 ? 快 速访问数据表中的特定信息, 提高检索速度 创 建唯一性索引, 保证数据库表中每一行数据的唯一性。 加 速表和表之间的连接 使用分组和排序子句进行数据检索时, 可以显著减少查询中分组和排序的时间 2、 索引对数据库系统的负面影响是什么? 负面影响: 创建 索引和维护索引需要耗费时间, 这个时间随着数据量的增加而增加; 索引需 要占 用物理空间, 不光是表需要占用数据空间, 每个索引也需要占用物理空间; 当 对 表 进行增、 删、 改、 的时候索引也要动态维护, 这样就降低了数据的维护速 度 。 3、 为数据表建立索引的原则有哪些? 在 最频繁使用的、 用以缩小查询范围的字段上建立索引。在 频繁使用的、 需要排序的字段上建立索引 4、 什 么 情 况 下 不 宜 建 立 索 引 ? 对于查询中很少涉及的列或者重复值比较多的列, 不宜建立索引。 对于一些特殊的数据类型, 不宜建立索引, 比如文本字段(text) 等 37、解释 MySQL 外连接、内连接与自连接的区别 先说什么是交叉连接: 交叉 连接 又叫 笛卡 尔积 ,它是 指不 使用 任何 条件 ,直接 将一 个表的所有记录和另一个表中的所有记录一一匹配。 内连接 则是只有条件的交叉连接, 根据某个条件筛选出符合条件的记录 , 不符合条件的记录不会出现在结果集中, 即内连接只连接匹配的行。 外连接 其结果集中不仅包含符合连接条件的行, 而且还会包括左表、 右表或两个表中的所 有数据行, 这三种情况依次称之为左外连接, 右外连接, 和全外连接。 左外 连接, 也称左连接, 左表为主表, 左表中的所有记录都会出现在结果集中, 对于那些在右表中并没有匹配的记录, 仍然要显示, 右边对应的那些字段值以 NULL 来填充。右外连接,也称右连接,右表为主表,右表中的所有记录都会出现 在结果集中。 左连接和右连接可以互换, MySQL 目前 还不支持全外连接。
点赞 12
评论 1
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
06-03 14:43
已编辑
江苏省宝应中学 后端
2025年5月9日 滴滴求储Java一面
自我介绍:面试官好,我是**大学 27 届本科生,来自计算机科学技术学院。从大一开始我就进入了 我们学校的实验室进行学习 Java,我在大一上学完了 Java 基础 , 大一下学习了 Javaweb 开发和 spring 框架以及 springboot 的使用.我在大一暑假速成学习了前端 vue在大二上学期进行一段 三个月的小厂实习,大二寒假我参加了字节青训,完成了前后端两个项目,并且写了自己的开源项目大二下学期参加了 acm 算法竞赛获得了三块铜牌,完成了学校的实验室的博客论坛项目部署上线并且系统学习了阿里体系的电商项目。实习:实习项目中遇到的挑战是什么?(todo)这个问题需要提前准备一下...
27双非 Java后端开...
面试问题记录
牛客创作赏金赛
点赞
评论
收藏
分享
05-29 12:15
北京理工大学 整车软件集成工程师
有时候听取前辈的建议还是很不错的!(工作跳槽版)
最近刚刚换了工作,但是我工作年限真的很短很短,和新的mt去吃饭的时候,她跟我讲了一些她的意见,对于我来说是非常有用的,我来分享给大家,针对工作的年限如果自身不够硬的话就要在一个阶段足够的淬炼自己,方可进化成为职场no.1一个人的事业发展一般可以分几个阶段:第一阶段: 干活小弟(1-3年)干活小弟主要承接老板交代的工作,工作不需要承担太多责任,为老板打杂打下手,没有什么话语权,是学习技能的阶段第二阶段:大头兵(3-5年)这个时候你从一个执行小弟,变成一个可以独当一面的骨干专家。可以从执行者变成一个决策者,自己承担项目的闭环,需要拥有一些全局观和推动力。第三阶段:小组长(4-8年)从一个个人贡献者...
小涵干货小课堂
如果公司降薪,你会跳槽吗?
点赞
评论
收藏
分享
05-17 11:07
桂林航天工业学院 运营
一年了
感觉自己素质越来越低了
求offer的大角牛:
不吃香菜
点赞
评论
收藏
分享
04-12 23:18
华南理工大学 嵌入式软件开发
26届嵌入式软件暑期实习简历求建议
目前没收到一个中大厂的面试,是不是简历有问题啊😭😭
放浪的安哥拉兔躺平了:
嵌入式行情太差了,试试去投腾讯客户端,嵌入式的简历也会给面试的
那些拿到大厂offer的简历长啥样
投了多少份简历才上岸
点赞
评论
收藏
分享
05-29 12:11
北京联合大学 C++
如何优雅而不失礼貌的拒绝dirtywork?
新人往往不敢拒绝,怕得罪人,但又不能当软柿子任人拿捏。和大家说说一些常用的拒绝话术和策略,早一点拜托dirtywork!核心原则:态度真诚,语气坚定但温和: 避免显得傲慢或推诿。保持礼貌、专业。表达理解与感谢: 先让对方感到被尊重和理解。清晰说明原因(必要时): 简洁说明拒绝的原因(通常聚焦在优先级、时间、职责范围)。提供替代方案(如果可能): 展现合作意愿,帮忙指条明路。不轻易承诺或过度道歉: 不要为拒绝而过度内疚或道歉,这显得底气不足。避免说“我试试看”这种模糊承诺。及时回应: 不要拖延,尽快给出明确答复。🍊几个实用拒绝话术分场景:场景一:拒绝同事临时增加的、非本职或低优先级的杂事/请求...
Maples31:
差点看成了如何拒绝 dirty talk,我还寻思这给我干哪来了
一人一个landing小技巧
职场新人生存指南
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
我被光速开除了……
1.6W
2
...
找实习三个月,感觉已无心气
4227
华为开奖进度👉
热聊中
3
...
字节last day,知无不言!
4187
4
...
字节暑期捡漏!附面经
4106
5
...
分享我的秋招之路(2025届版)
4041
6
...
作为面试官,比较喜欢听到「实习收获」回答是什么样的?
3800
7
...
🐧应届生选offer防踩坑指南:为什么"有鹅选鹅"是当前最佳策略?
3306
8
...
27届双非-Cider一面-/6/4
2683
9
...
你的经历比较单薄, 但简历又弥补了这一点--双非仔个人简历分享
2652
10
...
只有收到offer那一刻是开心的
2448
创作者周榜
更多
正在热议
更多
#
晒一晒你的工位
#
76825次浏览
256人参与
#
24届的你们现状如何了?
#
69333次浏览
399人参与
#
写给毕业5年后的自己
#
8049次浏览
138人参与
#
电网笔面经互助
#
33166次浏览
331人参与
#
职场捅娄子大赛
#
340381次浏览
3430人参与
#
实习中的菜狗时刻
#
358480次浏览
3269人参与
#
今年形式下双非本找得到工作吗
#
137557次浏览
1041人参与
#
我的第一份实习怎么找的
#
102099次浏览
1005人参与
#
工作压力大怎么缓解
#
77912次浏览
925人参与
#
想给25届机械人的秋招建议
#
26451次浏览
219人参与
#
机械人,你的秋招第一份简历被谁挂了
#
137763次浏览
1972人参与
#
入职第三天,晒晒你的工位
#
30633次浏览
144人参与
#
25届非技术实习投递记录
#
116318次浏览
969人参与
#
实习必须要去大厂吗?
#
95232次浏览
1337人参与
#
你最满意的offer薪资是哪家公司?
#
25293次浏览
129人参与
#
面试被问期望薪资时该如何回答
#
248491次浏览
1444人参与
#
腾讯求职进展汇总
#
832291次浏览
8830人参与
#
请用你的专业向妈妈表白
#
15858次浏览
111人参与
#
选完offer后,你后悔学机械吗?
#
28685次浏览
157人参与
#
你的秋招第一场笔试是哪家
#
129344次浏览
1404人参与
牛客网
牛客企业服务