测试基础笔记第九天

news2025/4/24 23:10:45

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 一、数据类型和约束
    • 1.数据类型
    • 2.约束
    • 3.主键
    • 4.不为空
    • 5.唯一
    • 6.默认值
  • 二、数据库操作
    • 1.创建数据库
    • 2.使用数据库
    • 3.修改数据库
    • 4.删除数据库和查看所有数据库
    • 5.重点:数据库备份
      • 1.应用场景
      • 2.备份方法
      • 3.还原操作
      • 4.扩展:使用命令备份
  • 三、数据表操作
    • 1.创建表
    • 2.查看表
    • 3.判断表存在移除再创建
    • 4.扩展:通过 Navicat 工具获取创表语句的方法
    • 5.查看表结构和删除表
  • 四、数据操作
    • 1.增加数据
      • 1.增加一行数据
      • 2.增加多行数据
      • 3.修改数据
      • 4.数据删除
      • 5.扩展:逻辑删除


一、数据类型和约束

1.数据类型

  • 说明:对于填入的数据值本身进行控制,保证数据准确性
  • 整数: 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’
  • 在这里插入图片描述

2.约束

  • 说明:对于整张表进行限制,确保对应字段的所有数据符合设计要求
  • 主键(primary key): 能唯一标识表中的每一条记录的属性组
  • 非空(not null): 此字段不允许填写空值
  • 唯一(unique): 此字段的值不允许重复
  • 默认值(default): 当不填写此值时会使用默认值,如果填写时以填写为准
  • 外键(foreign key): 一个表中的一个字段引用另一个表的主键

3.主键

在这里插入图片描述

4.不为空

在这里插入图片描述

5.唯一

在这里插入图片描述

  • 选择索引类型为:unique(唯一)
    在这里插入图片描述

6.默认值

在这里插入图片描述

二、数据库操作

1.创建数据库

创建数据库
– create database 数据库名 charset=utf8 collate=utf8_general_ci;
create database python charset=utf8 collate=utf8_general_ci;
– 查看数据库
– show create database 数据库名;
show create database python;

2.使用数据库

– 使用数据库(切换数据库)
– use 数据库名;
use python;
– 查看当前数据库: database() 是 SQL 的内置函数, 括号不能省略!
select database();

3.修改数据库

– 修改数据库
– 创建
create database testpython charset = gb2312;
– 修改
– alter database 数据库名
– default character set 编码格式
– default collate 排序规则;
alter database testpython
default character set utf8mb4
default collate utf8mb4_general_ci;

4.删除数据库和查看所有数据库

– 删除数据库
– drop database 数据库名;
drop database python;
– 查看所有数据库
show databases;

5.重点:数据库备份

1.应用场景

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

2.备份方法

  • 数据库 -> 转储 SQL ⽂文件 -> 结构+数据
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

3.还原操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.扩展:使用命令备份

在这里插入图片描述
命令备份与还原数据库操作
在这里插入图片描述

三、数据表操作

1.创建表

– 创建表
– 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)
);

2.查看表

– 查看表信息
– show create table 表名;
show create table students;
– 执行结果
– CREATE TABLE students (
id int(10) unsigned NOT NULL AUTO_INCREMENT,
name varchar(20) DEFAULT NULL,
age int(10) unsigned DEFAULT NULL,
height decimal(5,2) DEFAULT NULL,
– PRIMARY KEY (id)
– ) ENGINE=InnoDB DEFAULT CHARSET=utf8

3.判断表存在移除再创建

– 扩展: 判断表是否存在, 存在时先删除再创建
– 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)

4.扩展:通过 Navicat 工具获取创表语句的方法

在这里插入图片描述

5.查看表结构和删除表

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

四、数据操作

1.增加数据

1.增加一行数据

  • 增加数据
    – 增加一行数据
    – 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);

2.增加多行数据

– 插入多行数据
– 方式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);

3.修改数据

– 修改数据
– update 表名 set 列1=值1,列2=值2… where 条件
– 注意: where 不能省略, 否则会修改整列数据
update students set age=48 where id=9;
在这里插入图片描述

4.数据删除

– 删除数据
– delete from 表名 where 条件;
– 注意: where 不能省略, 否则会删除全部数据
delete from students where id=6;

5.扩展:逻辑删除

  • 逻辑删除: 对于重要的数据,不能轻易执行 delete 语句进行删除。因为一旦删除,数据无法恢复,这时可以进行逻辑删除。
    1、给表添加字段,代表数据是否删除,一般起名 isdelete,0代表未删除,1代表删除,默认值为0
    2、当要删除某条数据时,只需要设置这条数据的 isdelete 字段为1
    3、以后在查询数据时,只查询出 isdelete 为0的数据

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2342005.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python爬虫与代理IP:高效抓取数据的实战指南

目录 一、基础概念解析 1.1 爬虫的工作原理 1.2 代理IP的作用 二、环境搭建与工具选择 2.1 Python库准备 2.2 代理IP选择技巧 三、实战步骤分解 3.1 基础版:单线程免费代理 3.2 进阶版:多线程付费代理池 3.3 终极版:Scrapy框架自动…

Unity 将Excel表格中的数据导入到Mysql数据表中

1.Mysql数据表users如下: 2.即将导入的Excel表格如下: 3.代码如下: using System; using System.Data; using System.IO; using Excel; using MySql.Data.MySqlClient; using UnityEngine; using UnityEditor;public class ImportExcel {// …

JavsScript 原型链

解决构造函数浪费内存的问题 每一个构造函数都有一个属性prototype属性,指向一个原型对象 原型是构造函数的一个属性 prototype 给数组类型扩展 正常代码: prototype中的this指向为调用对象 所以 基本关系:构造函数产生两个部分&…

消息中间件RabbitMQ02:账号的注册、点对点推送信息

一、默认用户登录和账号注册 1.登录 安装好了RMQ之后,我们可以访问如下地址: RabbitMQ Management 输入默认的管理员密码,4.1.0的管理员账号和密码是: guest guest 2.添加账号 consumer consumer 添加成功后: 角色…

大语言模型的评估指标

目录 一、混淆矩阵 1. 混淆矩阵的结构(二分类为例) 2.从混淆矩阵衍生的核心指标 3.多分类任务的扩展 4. 混淆矩阵的实战应用 二、分类任务核心指标 1. Accuracy(准确率) 2. Precision(精确率) 3. …

好用————python 库 下载 ,整合在一个小程序 UIUIUI

上图~ import os import time import threading import requests import subprocess import importlib import tkinter as tk from tkinter import ttk, messagebox, scrolledtext from concurrent.futures import ThreadPoolExecutor, as_completed from urllib.parse im…

OpenVINO教程(五):实现YOLOv11+OpenVINO实时视频目标检测

目录 实现讲解效果展示完整代码 本文作为上篇博客的延续,在之前实现了图片推理的基础上,进一步介绍如何进行视频推理。 实现讲解 首先,我们需要对之前的 predict_and_show_image 函数进行拆分,将图像显示与推理器(pre…

CentOS的安装以及网络配置

CentOS的下载 在学习docker之前,我们需要知道的就是docker是运行在Linux内核之上的,所以我们需要Linux环境的操作系统,当然了你也可以选择安装ubuntu等操作系统,如果你不想在本机安装的话还可以考虑买阿里或者华为的云服务器&…

「Java EE开发指南」用MyEclipse开发EJB 3无状态会话Bean(二)

本教程介绍在MyEclipse中开发EJB 3无状态会话bean,由于JPA实体和EJB 3实体非常相似,因此本教程不涉及EJB 3实体Bean的开发。在本教程中,您将学习如何: 创建EJB 3项目创建无状态会话bean部署并测试bean 在上文中(点击…

深度学习在DOM解析中的应用:自动识别页面关键内容区块

摘要 本文介绍了如何在爬取东方财富吧(https://www.eastmoney.com)财经新闻时,利用深度学习模型对 DOM 树中的内容区块进行自动识别和过滤,并将新闻标题、时间、正文等关键信息分类存储。文章聚焦爬虫整体性能瓶颈,通…

PyQt6实例_pyqtgraph多曲线显示工具_代码分享

目录 概述 效果 代码 返回结果对象 字符型横坐标 通用折线图工具 工具主界面 使用举例 概述 1 分析数据遇到需要一个股票多个指标对比或一个指标多个股票对比,涉及到同轴多条曲线的显示,所以开发了本工具。 2 多曲线显示部分可以当通用工具使…

Linux网络编程 多线程Web服务器:HTTP协议与TCP并发实战

问题解答 TCP是如何防止SYN洪流攻击的? 方式有很多种,我仅举例部分: 1、调整内核参数 我们知道SYN洪流攻击的原理就是发送一系列无法完成三次握手的特殊信号,导致正常的能够完成三次握手的信号因为 连接队列空间不足&#xff…

Qt 下载的地址集合

Qt 下载离线安装包 download.qt.io/archive/qt/5.14/5.14.2/ Qt 6 安装下载在线安装包 Index of /qt/official_releases/online_installers/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

ubuntu下gcc/g++安装及不同版本切换

1. 查看当前gcc版本 $ gcc --version# 查看当前系统中已安装版本 $ ls /usr/bin/gcc*2. 安装新版本gcc $ sudo apt-get update# 这里以版本12为依据(也可以通过源码方式安装,请自行Google!) $ sudo apt-get install -y gcc-12 g…

FPGA入门学习Day1——设计一个DDS信号发生器

目录 一、DDS简介 (一)基本原理 (二)主要优势 (三)与传统技术的对比 二、FPGA存储器 (一)ROM波形存储器 (二)RAM随机存取存储器 (三&…

微信小程序拖拽排序有效果图

效果图 .wxml <view class"container" style"--w:{{w}}px;" wx:if"{{location.length}}"><view class"container-item" wx:for"{{list}}" wx:key"index" data-index"{{index}}"style"--…

WT2000T专业录音芯片:破解普通录音设备信息留存、合规安全与远程协作三大难题

在快节奏的现代商业环境中&#xff0c;会议是企业决策、创意碰撞和战略部署的核心场景。然而&#xff0c;传统会议记录方式常面临效率低、信息遗漏、回溯困难等痛点。如何确保会议内容被精准记录并高效利用&#xff1f;会议室专用录音芯片应运而生&#xff0c;以智能化、高保真…

【Python 学习笔记】 pip指令使用

系列文章目录 pip指令使用 文章目录 系列文章目录前言安装配置使用pip 管理Python包修改pip下载源 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 当前文章记录的是我在学习过程的一些笔记和思考&#xff0c;可能存在有误解的地方&#xff0c;仅供大家…

C# 文件读取

文件读取是指使用 C# 程序从计算机文件系统中获取文件内容的过程。将存储在磁盘上的文件内容加载到内存中&#xff0c;供程序处理。主要类型有&#xff1a;文本文件读取&#xff08;如 .txt, .csv, .json, .xml&#xff09;&#xff1b;二进制文件读取&#xff08;如 .jpg, .pn…

leetcode125.验证回文串

class Solution {public boolean isPalindrome(String s) {s s.replaceAll("[^a-zA-Z0-9]", "").toLowerCase();for(int i0,js.length()-1;i<j;i,j--){if(s.charAt(i)!s.charAt(j))return false;}return true;} }