数据库学习——第一天

数据库

今日内容:

数据类型和约束
通过 SQL 语句实现⼀系列操作
对数据库的操作
对数据表的操作
对数据的操作(增/删/改)


说明: 数据库是专⻔⽤来存储数据的软件
注意: 对于测试⼯作⽽⾔, 如果项⽬⻚⾯没有实现, 但是我们⼜想要校验数据,
则可以直接通过查询数据库实现
关系: 具体存在的商品录⼊后 -> 产⽣对应的数据(存到数据库中) -> 最后会被
加载到项⽬⻚⾯中

数据库的分类

分类:
 1> 关系型数据库: 以数据表为核⼼
 2> ⾮关系型数据库: 不存在数据表的概念
关系型数据库: RDMS(Relational Database Management System)关系型数
据库系统
常⻅的关系型数据库:
 Oracle: 在⼤型项⽬中使⽤,例如:银⾏、电信等项⽬
 MySQL: Web 项⽬中使⽤最⼴泛的关系型数据库
 Microsoft SQL Server: 在微软的项⽬中使⽤
 SQLite: 轻量级数据库,主要应⽤在移动平台
关系型数据库的核⼼要素:
 数据⾏(⼀条记录)
 数据列(字段)
 数据表(数据⾏的集合)
 数据库(数据表的集合,⼀个数据库中能够有 n 多个数据表)

SQL 语⾔

说明: SQL:Structured Query Language(结构化查询语⾔),通过 SQL 语
⾔可以对数据库进⾏操作
注意:
 1. SQL 语⾔默认⽀持操作所有常⻅的关系型数据库
 2. 作为测试⼈员, 必须要掌握 SQL 的查询语句
 (DQL:数据查询语⾔,⽤于对数据进⾏查询,例如:select)
 3. 对于 MySQL ⽽⾔, 编写 SQL 语句时, 不区分字⺟的⼤⼩写

MySQL 数据库介绍

说明: MySQL 是⼀个关系型数据库管理系统,⽬前属于 Oracle 旗下产品, ⽬
前为⽌ MySQL 社区版是可以免费使⽤的
特点: 开源/免费/跨平台(Windows/macOS/Linux)/跨语⾔(Java/Python...)

数据库连接⼯具 Navicat

说明: 由于数据库软件处于服务器中, 想要操作数据库, 就必须使⽤⼯具远程连
接数据库后, 进⾏操作

连接数据库操作步骤

说明: 将来在⼯作中, 想要远程连接数据库, 需要具备以下条件:
 1> 数据库所在服务器的 IP 地址及数据库的端⼝号
 2> 向相关⼈员获取数据库的账号和密码
 3> 使⽤数据库连接⼯具, 远程连接数据库即可
注意: 远程连接需要注意⽹络连通性

数据类型和约束

数据类型

数据类型: 对于填⼊的数据值本身进⾏控制, 保证数据准确性

整数: int,有符号范围(-2147483648 ~2147483647),⽆符号
(unsigned)范围(0 ~
4294967295)
⼩数: decimal,例如:decimal(5,2) 表示共存5位数,⼩数占2位,整数占3
位
字符串: varchar,范围(0~65533),例如:varchar(3) 表示最多存3个字
符,⼀个中⽂或⼀个字
⺟都占⼀个字符
⽇期时间: datetime,范围(1000-01-01 00:00:00 ~ 9999-12-31
23:59:59),例如:'2020-01-
01 12:29:59'
约束

约束: 对于整张数据表进⾏限制, 确保对应字段的所有数据符合设计要求

主键(primary key): 能唯⼀标识表中的每⼀条记录的属性组
⾮空(not null): 此字段不允许填写空值
唯⼀(unique): 此字段的值不允许重复
默认值(default): 当不填写此值时会使⽤默认值,如果填写时以填写为准
外键(foreign key): ⼀个表中的⼀个字段引⽤另⼀个表的主键
数据库操作
-- 创建数据库
-- create database 数据库名 charset=utf8 collate=utf8_general_ci;
create database python charset=utf8 collate=utf8_general_ci;
-- 查看数据库
-- show create database 数据库名;
show create database python;
使用数据库
-- 使⽤数据库(切换数据库)
-- use 数据库名;
use python;
-- 查看当前数据库: database() 是 SQL 的内置函数, 括号不能省略!
select database();
修改数据库
-- 修改数据库
-- 创建
create database testpython charset = gb2312;
-- 修改
-- alter database 数据库名
-- default character set 编码格式
-- default collate 排序规则;
alter database testpython
default character set utf8mb4
default collate utf8mb4_general_ci;
删除数据库和查看所有数据库
-- 删除数据库
-- drop database 数据库名;
drop database python;
-- 查看所有数据库
show databases;

重点: 数据库备份

应用场景
说明: 在测试⼯作中, 为了防⽌对数据库产⽣错误操作, 或产⽣垃圾数据, 都需
要在操作前, 适当对数据库进⾏备份操作.
垃圾数据: 例如在⾃动化测试中, 对注册模块操作⽣成的所有数据, 属于典型的
垃圾数据, 应该清理

数据库 -> 转储 SQL ⽂件 -> 结构+数据

扩展: 使⽤命令备份

在这里插入图片描述

备份:mysqldump -uroot -p test > python.sql;

还原:mysql -uroot -p test <python.sql;

数据表操作

创建表

-- 创建表
-- create table 表名(
-- 字段名 类型 约束,
-- 字段名 类型 约束
-- ...
-- )
-- 简单创建
create table stu(
 name varchar(5));
-- 完整创建
-- unsigned : ⽆符号
-- primary key : 主键
-- auto_increment : ⾃动增⻓
create table students(
 id int unsigned primary key auto_increment,
 name varchar(20),
 age int unsigned,
 height decimal(5,2)
);

查看表

show create table students;

扩展: 判断表存在移除再创建

-- 扩展: 判断表是否存在, 存在时先删除再创建
-- drop table : 删除表
-- if exists students : 如果 students 存在
drop table if exists students;
create table students(
 id int unsigned primary key auto_increment,
 name varchar(20),
 age int unsigned,
 height decimal(5,2)
);

扩展: 通过 Navicat ⼯具获取创表语句的⽅法

在这里插入图片描述

查看表结构和删除表

-- 查看表结构(字段)
-- desc 表名;
desc students;
-- 删除表
-- drop table 表名;
drop table students;

数据操作

增加数据

增加数据
-- 增加数据
-- 增加⼀⾏数据
-- insert into 表名 values(...)
-- 注意:
-- 1. 数据值需要和表的字段⼀⼀对应(数据个数及数据类型)
-- 2. 主键列是⾃动增⻓,插⼊时需要占位,通常使⽤ 0 或者 default 或者
null 来占位,插⼊成功后以实际数据为准
insert into students values(0, '张三', 28, 1.78);
-- 增加部分值
-- insert into 表名(字段1,...) values(值1,...)
-- 注意: 值的顺序与给出的字段顺序对应
insert into students(name, height) values('李四', 1.68);
增加多⾏数据
-- 插⼊多⾏数据
-- ⽅式1: 将单⾏插⼊语句, 多句执⾏, 每句分号隔开
insert into students values(0, '王五', 28, 1.78);
insert into students(name, height) values('赵六', 1.68);
-- ⽅式2: 在插⼊单⾏数据的语法基础上, 将 value 后边的数据进⾏多组化处-- insert into 表名 values(...),(...)...
-- insert into 表名(列1,...) values(值1,...),(值1,...)...
insert into students values(0, '王五1', 29, 1.78),(0, '王五2',
30, 1.78);
insert into students(name, height) values('赵六1', 1.78),('赵六
2', 1.88);
修改数据
-- 修改数据
-- update 表名 set 列1=值1,列2=值2... where 条件
-- 注意: where 不能省略, 否则会修改整列数据
update students set age=48 where id=9;
删除数据
-- 删除数据
-- delete from 表名 where 条件;
-- 注意: where 不能省略, 否则会删除全部数据
delete from students where id=6;
扩展 1: 逻辑删除
逻辑删除: 对于重要的数据,不能轻易执⾏ delete 语句进⾏删除。因为⼀旦删
除,数据⽆法恢复,这
时可以进⾏逻辑删除。
1、给表添加字段,代表数据是否删除,⼀般起名 isdelete,0代表未删除,1代
表删除,默认值为0
2、当要删除某条数据时,只需要设置这条数据的 isdelete 字段为1
3、以后在查询数据时,只查询出 isdelete 为0的数据
-- 扩展 1: 逻辑删除(假删/标记删除)
-- 1> 修改要删除的数据的特定字段为删除状态
update students set isdelete=1 where id=4;
-- 2> 查询所有 isdelete 字段为 0 的所有数据
select * from students where isdelete=0;
扩展 2: 其他删除数据的⽅法
-- 扩展 2: 其他数据删除⽅法
-- delete from 表名 : 删除所有数据, 但是不重置主键字段的计数
-- truncate table 表名 : 删除所有数据, 并重置主键字段的计数
-- drop table 表名 : 删掉表(字段和数据均不再存在)
delete from students;
truncate table students;
drop table students;

在这里插入图片描述
声明:是学习黑马测试教程的,有兴趣可以点击链接学习学习入口

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值