软件测试面试题:数据库大厂面试真题

本文深入探讨了数据库中的索引优化,解释了为什么`select *`效率低,阐述了索引的作用及并非越多越好的原因。此外,文章还详细介绍了ORM(对象关系映射)的概念、作用以及使用ORM的优势,最后对比了关系型数据库和非关系型数据库的区别,包括数据存储方式、扩展方式和事务性支持。
摘要由CSDN通过智能技术生成

一、数据库

1.为什么select *  这种方式效率低?

1.1不需要的列会增加时间传输时间和网络开销,尤其是大类型的字段:text  varchar

1.2对于无用的大字段,会增加IO操作

1.3将失去mysql优化器"覆盖索引"策略优化的可能性

 

2.什么是索引?索引为什么能增加查询效率?

2.1数据库当成一本新华字典,索引就是这个字典的目录,一般会针对where条件后面得字段

show INDEX from 'order'       #查询某个表的索引

2.2主键本身就是一种唯一索引

 

3.索引是建的越多越好吗?

答案:不是。原因如下:

3.1建索引会占用空间

首先,在数据库表中创建索引,这些索引也是数据,也是需要占用磁盘空间的。而磁盘是和cpu、内存一样重要的资源,尤其是数据库是用来保存数据的,会大量的耗费磁盘。

所以磁盘空间,是建索引要考虑的其中一项。

3.2维护索引需要耗费性能

索引其实就类似新华字典的目录页类似。假设我们要在新华字典里新增加一个字,那必然要重新维护一下新华字典的目录页

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值