软件测试之数据库入门
文章目录
前言
随着IT行业的不断发展,软件测试这门技术也越来越重要,很多外行小白都开启了学习软件测试,本文就软件测试之数据库入门内容展开介绍。
以下是本篇文章正文内容,如有表达不全的问题还请指出,本文中插入的图片由网上下载,如涉及版权问题联系我删除。
一、理解数据库
(1)数据库DB
将数据放在表里,再一起存入仓库中。
(2)数据库种类
- 关系数据库(常用):二维表格模型存储数据(同excel的行和列)
数据库中如果一张表要关联其他表,通过对应的列产生了关系。
关系数据库=多张表+各表之间的关系
例如:MySQL(常用)、Oracle(常用)、SQL Server、SQLite等 - 非关系数据库NoSQL:使用k-v键值对存储数据,易扩展
例如:MongoDb、redis等
(3)如何操作数据库增删改查–sql语句
通过sql结构化查询语言来操作数据库里的数据,可以对数据进行CRUD(增删改查)
(4)数据库管理系统DBMS
用来管理数据库的软件,关系数据库管理系统有MySQL、Oracle、SQL Server等;
(5)为什么要使用数据库而不使用excel表
- excel:储存量有限,访问速度及处理速度在数据量大时也是短板
- 数据库:可存储的数据量大,读取效率高,可用于复杂的查询,兼容性高,持久化数据。千言万语一句话:方便、效率、安全
二、mysql数据库安装
1.mysql数据库安装
微信搜索“应用软件之家”公众号,进入软件目录可找到mysql的安装包和步骤。
注意点:修改mysql用户名密码的时候点击modify security settings复选框后,用户名和密码我都是输入的root才能继续下一步操作。
2.mysql图形化工具–Navicat安装
图形化工具:直观的在任何地点高效地管理你的数据库。
如果不用图形化工具去操作那就直接进入cmd终端去操作也可以。
微信搜索“应用软件之家”公众号,进入软件目录可找到Navicat的安装包和步骤。
三、测试人员应该掌握的数据库操作
初级:增删改查操作
高级:单元测试-语句覆盖、数据库性能分析、安全测试-sql注入
1、Navicat连接本地数据库
新建mysql---->输入安装mysql时设置的用户名和密码,默认端口是3306---->右击test数据库新增user表,并新增主键、姓名、年龄字段,插入两条数据记录。
注:如果插入不了中文数据,可以右击表名,点击设计表,将varchar类型数据的字符集改为utf8。
2、常用sql命令
查询语句show
(1)展示所有数据库
show datebases;
(2)使用test数据库
use test;
(3)展示所有数据库表
show tables;
查询语句select
(1)查询user表的数据
select * from user;
(2)查询包含zhang的记录,%的位置可以匹配出多个字符(%:匹配多个字符;-
:匹配一个字符)
select * from user where name like '%zhang%';
(3)查询包含hang的记录,-
的位置可以匹配一个字符(%:匹配多个字符;-
:匹配一个字符)
select * from user where name like '%_hang%;
(4)查询包含hang的记录,只展示name和age两个字段的信息
select name,age from user where name like '%_hang%';
(5)查询user前3行的数据
select * FROM user limit 3;
新增语句insert
(1)在user表里插入一行数据(字段和值需要一一对应)
insert into user (name,age) values ('wangwu','19');
(2)把user表里现有数据追加到user表后
insert into user (name,age) SELECT name,age FROM user;
修改语句update
(1)将user表中name等于wangwu的age更新为40
update user set age='40' where name='wangwu';
(2)设置更新安全模式(0或1,0表示可以操作,1表示不可以,如果设置为1再执行更新操作,name会提示 You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column错误)
set sql_safe_updates = 1;
删除语句delete
(1)删除user表里name等于zhangsan的所有记录
delete FROM user where name = 'zhangsan';
连接查询
连接查询–内连接inner join on
查询两个表的交集。
例如:查询user和major两张表中的交集(user表的major字段=major表的name字段即为交集部分),展示的结果将两张表的交集数据合为一张表展示,如下图所示。
SELECT * FROM `user` inner join major on user.major = major.name;
连接查询–外连接
1、左外连接left join on
例:user表左连接major表,意思是根据user表去查major表,将左边的user作为主表,返回左表的所有行,右表没匹配上的行数据为null,所下图所示。
SELECT * FROM `user` left join major on user.major = major.name;
2、右外连接right join on
例:user表右连接major表,意思是根据user表去查major表,将右边的major作为主表,返回右表的所有行,左表没匹配上的行数据为null,所下图所示。
SELECT * FROM `user` right join major on user.major = major.name;
3、cmd终端操作数据库
开始菜单–>找到mysql command line clinet—>点击打开cmd窗口—>输入设置的密码回车—>直接在mysql>后输入sql语句也可以。
例如:
注:终端显示中文为?解决办法:
1、查看编码
show variables like 'char%';
2、设置编码:
set character_set_results=utf8;
如下图所示:
总结
以上就是今天要讲的内容,本文仅仅简单介绍了数据库入门的一些基础内容,有描述错误的地方请指出,感谢观看。