百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

功能测试只是入门!数据库测试深度解析,你了解多少?

mhr18 2025-02-19 13:04 20 浏览 0 评论

我们平常使用的网站、APP和桌面客户端等软件,都离不开一个叫做数据库的东西的助力,数据库就像一个商店的仓库,如果没有这个仓库,那么商店就不能提供给顾客任何实质性的物品。目前数据库技术已经渗透到比如政务,金融,银行,医疗,军工,互联网行业等,而随着软件体量的增长,曾经被忽略的数据库功能、性能和安全都越来越急需得到更多的质量保障。

相信很多测试小伙伴一开始做功能测试(黑盒测试)时,更多地关注的是前端UI、主要功能和逻辑的实现,而忽略了数据库的测试,或者说在数据库这块只是进行简单的增删改查检查就草草结束了。其实数据库要测试的方面有很多,今天就列举一些和大家分享。

首先我们来认识一下目前主流的数据库

项目开发中主要还是用的关系型数据库:

比如MySQL,Oracle,MicrosoftSQLServer,DB2,MicrosoftAccess等。

当然除了关系型数据库还有非关系型数据库:比如Redis,MongoDB等。

关系型数据库:使用表格(表)来组织数据,表之间通过关系建立连接,数据以结构化的行和列存储,遵循固定的模式(模式定义在数据库的表结构中),使用表格的行和列,表格之间通过外键建立关系,每个表有固定的列,行必须符合表的结构。强调数据一致性,保证任何时刻数据库都处于一致的状态。

非关系型数据库:使用各种数据模型,例如文档、键值对、列族、图等。数据可以以非结构化或半结构化的形式存储,而且不需要遵循固定的模式,数据结构更灵活,不同类型的数据可以存储在同一数据库中,而且每个记录可以有不同的字段,可能在一定程度上牺牲一致性以获取更高的性能和可用性。

对于数据库的操作主要集中:

一、增删改查模块

增删改查相信大家都是会做的,这边我就捎带提一下即可,有一点倒是需要强调,就是要检查一下字段边界和数据量边界,测试在字段的边界值上插入、更新或删除数据。测试在大型数据集上执行操作的性能和正确性。

二、数据库索引

验证数据库中的索引是否被正确使用。测试索引对查询性能的影响,包括索引的创建和删除。

1)测试基本的SELECT查询,包括涉及索引的查询和不涉及索引的查询。比较有索引和无索引情况下的查询性能,以确定索引对查询速度的影响。

2)验证索引对于排序操作的性能影响。测试涉及ORDERBY子句的查询,以确保索引在排序操作中的有效性。

3)如果使用了分区表,测试分区索引的性能。确保分区索引在查询时能够提供高效的性能。

三、数据库视图

测试数据库视图定义是否反映了用户的需求,视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。

1)检查视图的返回列是否与设计时定义的列一致。确保视图返回的数据类型符合预期。

2)如果视图接受参数,测试不同参数组合的情况。确保参数化视图在各种情况下都能正确工作。

3)测试视图与其他表或视图的连接是否正确。确保关联的数据能够正确地合并到视图中。

四、空数据库测试

将数据库表中所有的内容全部清空或者在系统喂数据前就进行测试,只留下一个管理员账户信息,检查系统的所有功能操作是否能够正常实现

五、测试数据库中数据的正确性或者完整性

测试数据库中数据的正确性和完整性是数据库测试中非常重要的一部分,涉及确保数据符合预期值、遵循业务规则和约束。

1)测试数据库表中的主键约束,确保每个记录都具有唯一的主键值。验证外键约束,确保外键引用的数据在关联表中存在。

2)确保设置了唯一性约束的字段中不允许重复值。确保设置了唯一性约束的字段中不允许重复值。

3)验证设置了默认值的字段在没有明确提供值的情况下是否能够正确地使用默认值。确保默认值符合业务规则和预期。

4)验证检查约束,确保字段值满足指定的条件。测试插入或更新数据时检查约束的行为。

5)确保每个字段的数据类型符合设计规范。测试插入或更新数据时数据类型的强制性。

6)如果数据库需要存储历史数据,测试历史数据的准确性和完整性。确保历史数据的时间戳和版本号等信息的正确性。

7)测试更新或删除数据时,确保数据的相关性和完整性得到维护。验证关联数据的级联更新或删除行为。

六、除了测试数据外,还要关注好数据库设计准则

数据库设计是确保数据库能够有效存储和管理数据的关键步骤。数据库设计的准则有:明确定义业务需求、标识实体和关系、规范化数据模型、选择适当的数据类型、保持数据的完整性、考虑性能需求、建立适当的索引、灵活考虑数据库范式、考虑安全性、版本控制数据库模式、数据库文档设计、性能测试和优化、备份和恢复策略等等方面,当你成为测试经验丰富后,是可以从这些维度出发给开发提提数据库的设计建议了。

七、数据库压力测试

在日常操作中的某一时刻,是否能够可以有效的承受来自多个用户的并发访问,并保持正常工作的过程。这种情况,可以借助于相关的测试工具来实现。

八、数据库SQL语句优化

这点在面试过程也是可能被问到的,为了你能全方面掌握SQL优化方法,我这边尽量说得详细点。数据库SQL语句优化是提高数据库查询性能的重要步骤,以下是一些常见的SQL语句优化技巧:

1)要使用索引:

-在查询中使用适当的索引,以加速数据检索。确保索引覆盖查询,以避免回表操作。

例:使用索引

SELECT*FROMusersWHEREusername='john';

避免全表扫描

SELECT*FROMusersWHEREusername='john'ANDstatus='active';

2)避免使用SELECT:

只选择实际需要的列,而不是使用`SELECT*`,以减小数据传输量。

例:只选择需要的列

SELECTuser_id,usernameFROMusersWHEREstatus='active';

3)使用JOIN时选择适当的连接方式:

根据实际需要选择INNERJOIN、LEFTJOIN、RIGHTJOIN等连接方式,以减小结果集。

例:使用INNERJOIN

SELECTorders.order_id,customers.customer_name

FROMorders

INNERJOINcustomersONorders.customer_id=customers.customer_id;

4)优化子查询:

尽量避免在查询中使用过多的子查询,可以考虑使用JOIN或其他连接方式替代。

例:使用JOIN替代子查询

SELECTproduct_name

FROMproducts

WHEREcategory_idIN(SELECTcategory_idFROMcategoriesWHEREcategory_name='Electronics');

使用JOIN

SELECTproducts.product_name

FROMproducts

INNERJOINcategoriesONproducts.category_id=categories.category_id

WHEREcategories.category_name='Electronics';

5)合理使用索引列:

在索引中选择最常用于过滤和排序的列。避免在大型表上创建过多的索引。

例:在WHERE和ORDERBY中使用索引列

CREATEINDEXidx_last_nameONemployees(last_name);

SELECT*FROMemployeesWHERElast_name='Smith'ORDERBYhire_date;

6)使用EXISTS替代IN:

在子查询中,使用`EXISTS`代替`IN`,因为`EXISTS`通常在子查询找到匹配项后立即返回。

例:使用EXISTS替代IN

SELECTcustomer_name

FROMcustomers

WHEREEXISTS(SELECT1FROMordersWHEREorders.customer_id=customers.customer_id);

7)合理使用数据库缓存:

使用适当的缓存机制,例如缓存查询结果或使用缓存工具,以避免相同的查询频繁访问数据库。

8)分页查询优化:

对于分页查询,使用`LIMIT`和`OFFSET`来限制返回的行数,避免一次性检索大量数据。

例:分页查询

SELECT*FROMproductsORDERBYproduct_idLIMIT10OFFSET20;

9)统计和分析执行计划:

使用数据库提供的工具分析和优化查询执行计划,以便了解查询的瓶颈和潜在问题。

例:查看执行计划

EXPLAINSELECT*FROMordersWHEREcustomer_id=123;

10)定期维护和优化:

定期进行数据库表的统计、索引的重建和数据库的优化,以确保数据库保持高性能状态。

这些优化技巧应根据具体的数据库系统和应用场景进行调整。对于复杂的查询和大型数据集,可能需要更深入的优化策略和工具。

总结:数据库测试是确保数据库系统正常运行、数据一致性、性能可靠以及安全可靠的关键流程。通过进行全面的数据库测试,企业可以确保其数据库系统能够可靠地支持业务需求,并能够及时、准确地提供数据。这有助于提高系统稳定性,减少潜在的安全风险,以及优化数据库性能。

文末了,我邀请你进入我们的软件测试学习交流群,大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,了解测试行业的最新趋势,助你快速进阶Python自动化测试/测试开发,稳住当前职位同时走向高薪之路。

最后:

1)关注+私信回复:“测试”,可以免费领取一份10G软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!

2)关注+私信回复:"入群" 就可以邀请你进入软件测试群学习交流~~

相关推荐

甲骨文签署多项大型云协议,其一未来可贡献超300亿美元年收入

IT之家7月1日消息,根据甲骨文Oracle当地时间6月30日向美国证券交易委员会(SEC)递交的FORM8-K文件,该企业在始于2025年6月1日的202...

甲骨文获TEMU巨额合同,后者大部分基础设施将迁移至Oracle云

IT之家6月23日消息,Oracle甲骨文创始人、董事长兼首席技术官LarryEllison(拉里埃里森)在本月早些时候的2025财年第四财季和全财年财报电话会议上表示,Oracle...

Spring Boot 自定义数据源设置,这些坑你踩过吗?

你在使用SpringBoot进行后端开发的过程中,是不是也遇到过这样的问题:项目上线后,数据库连接总是不稳定,偶尔还会出现数据读取缓慢的情况,严重影响了用户体验。经过排查,发现很大一部分原因竟然...

一个开箱即用的代码生成器(一个开箱即用的代码生成器是什么)

今天给大家推荐一个好用的代码生成器,名为renren-generator,该项目附带前端页面,可以很方便的选择我们所需要生成代码的表。首先我们通过git工具克隆下来代码(地址见文末),导入idea。...

低代码建模平台-数据挖掘平台(低代码平台的实现方式)

现在来看一下数据连接。·这里是管理数据连接的空间,点击这里可以新增一个数据连接。·输入连接名称,然后输入url,是通过gdbc的方式去连接的数据库,目前是支持mysql、oracle以及国产数据库达梦...

navicat 17.2.7连接oracle数据库提示加载oracle库失败

系统:macOS15.5navicat版本:navicatpremiumlite17.2.7连接oracle测试报错:加载oracle库失败【解决办法】:放达里面找到程序,显示简介里面勾选“使...

开源“Windows”ReactOS更新:支持全屏应用

IT之家6月17日消息,ReactOS团队昨日(6月16日)在X平台发布系列推文,公布了该系统的最新进展,包括升级Explorer组件,支持全屏应用,从Wine项目引入了...

SSL 推出采用全模拟内置混音技术的模拟调音台Oracle

英国调音台传奇品牌SolidStateLogic宣布推出Oracle——一款采用全模拟内置混音技术的调音台,在紧凑的AWS尺寸机箱内集成了大型调音台的功能。该调音台提供24输入和...

47道网络工程师常见面试题,看看有没有你不会的!

你们好,我的网工朋友。网络工程师面试的时候,都会被问到什么?这个问题其实很泛,一般来说,你肯定要先看明白岗位需求写的是什么。基本上都是围绕公司需要的业务去问的。但不可否认的是,那些最基础的概念,多少也...

汉得信息:发布EBS系统安装启用JWS的高效解决方案

e公司讯,从汉得信息获悉,近日,微软官方宣布InternetExplorer桌面应用程序将于2022年6月15日正式停用。目前大部分客户都是使用IE浏览器打开EBS的Form界面,IE停用后,只能使...

36.9K star ! 推荐一个酷炫低代码开发平台!功能太强!

前言最近在逛github,看看能不能搜罗到一些对自己有帮助的开源软件。不经意间看到一个高star的java开源项目:jeecg-boot。进入在线演示版一看,感叹实在是太牛了!此开源项目不管是给来学习...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

手把手教你在嵌入式设备中使用SQLite3

摘要:数据库是用来存储和管理数据的专用软件,使得管理数据更加安全,方便和高效。数据库对数据的管理的基本单位是表(table),在嵌入式linux中有时候它也需要用到数据库,听起来好难,其实就是几个函数...

JAVA语言基础(java语言基础知识)

一、计算机的基本概念什么是计算机?计算机(Computer)全称:电子计算机,俗称电脑。是一种能够按照程序运行、自动高速处理海量数据的现代化智能电子设备。由硬件和软件组成、没有安装过任何软件的计算机称...

再见 Navicat!一款开源的 Web 数据库管理工具!

大家好,我是Java陈序员。在日常的开发工作中,常常需要与各种数据库打交道。而为了提高工作效率,常常会使用一些可视化工具进行操作数据库。今天,给大家介绍一款开源的数据库管理工具,无需下载安装软件,基...

取消回复欢迎 发表评论: