网络安全快速入门(九)MySQL进阶操作

        上一章我们了解了对表及库的基本增删查改操作,本章我们针对增删查改内容进行与一些拓展,

9.1字段修饰及数据类型

        我们之前在创建表时用到的格式为:

create table 表名 (
字段名1 字段数据类型(数据类型长度),
字段名2 字段数据类型(数据类型长度),
字段名3 字段数据类型(数据类型长度),
字段名4 字段数据类型(数据类型长度),
)

        其实这个格式较为简单,仅仅定义了数据类型,但是大部分情况下无法只能通过数据类型来定义字段。因此我们可以拓展一下,在数据类型之后加上字段修饰,字段修饰有以下几个主要内容:

  • unsigned:表示的数字是无符号数字(只能是正数)
  • null:这个字段可以为空
  • not null:这个字段不可以为空
  • primary key:主键,用来唯一标识表中的一条记录(主键的内容不能重复)
  • auto_increment:设置主键自增
  • default:设置字段的默认值

我们来一个个讲解上述的字段修饰:

unsigned:

        表示该字段为无符号数字,顾名思义,也就是非负数。该字段只能紧跟在数据类型之后,否则会报错。

null:

该字段修饰可以让字段值为空,默认为null

not null:

        该字段不能让字段值为空,如果非空字段无值的情况下,会显示下图结果

primary key:

        主键,用来唯一标识表中的一条记录,该字段不能重复,通常用来作为序号,id等字段名称,

auto_increment:

        该修饰主要是用来做主键自增时使用,相关主键的数据类型尽量为数值型。

注意:在设置自增后主键轻易不要修改,因为主键自增后一般按照最大数值之后开始自增。贸然修改主键数值可能会导致之后的主键会从修改数值字段的最大值开始自增!!!

default:

设置字段默认值,在未改动该字段的情况下会默认为该字段修饰之后的字符

格式

字段名 数据类型 default “字符”

拓展创建表

 在了解字段修饰之后,我们就可以拓展一下之前我们所学习的创建表

 拓展格式如下

create table 表名 (
字段名1 字段数据类型(数据类型长度) 字段修饰,
字段名2 字段数据类型(数据类型长度)字段修饰,
字段名3 字段数据类型(数据类型长度)字段修饰,
字段名4 字段数据类型(数据类型长度)字段修饰,
)

话不多说,我们直接来举例

例:

在数据库db1下创建表格tb001表,要求:

name 为可变长度字符,50长度,

age为整型,三字符长度,且不能为空,

id为int长度,不能为空,且拥有主键并自加主键,

genger为可变长的字符,30长度,默认值为hebei,

nmum为枚举类型,枚举值为m和n

use db1;
create table tb001(
name varchar(50),
age int(3) not null,
id int not null primary key auto_increment,
genger varchar(30) default"hebei")

我们来查看一下上列命令的表结构

通过查看表结构我们可以发现我们上面所使用的字段名称,数据类型以及字段修饰,在上一篇文章我们已经讲解了各个字段的名称及含义,这里我们不再赘述。

补充:数据类型长度

不同数据类型长度所代表的含义不同,如果我们在char,或者varchar后加数据类型长度之后,该类型则可以最多输出数据类型长度的字符,如果是数值长度的话,输入少于字符长度的数据前面会自动用0去补全,如果超出长度则会原样显示出来,这里直接放截图

age int(3)时输入3显示的数据

age int(3)时输入333333显示的数据

而char或varchar输入超过该数据长度则会报错,char默认长度是1,这里请大家注意。

9.2对表中的数据进行操作

我们之前已经学习了对表的操作,接下来我们开始对表中的数据进行操作

在表中插入数据

        在表中插入数据有两种方法

  • 方法一
insert into 表名 values(值1,值2,值3)

        注意:该方法是依次给字段赋值,因此需要将字段逐个赋值

  • 方法二
insert into 表名(字段,字段,字段) values(值1,值2,值3)

        该方法可以指定字段进行赋值,因此方法二较为常用

这里我们举个例子

案例:

        在tb001中插入数据,name为ch225,age为66,genger为f

insert into tb001(name,age,genger)values("ch225",66,"f")

我们来看一下结果

注意:

  • 在赋值时候去注意字符类型,字母及文字需要用英文双引号引用,否则报错
  • 这里仅仅是向部分字段写入值
  • 没有指定字段,会写如空
  • 字段的顺序要和值的顺序保持一致

 删除表中的数据及截断表

删除表中的数据有两个格式,如下:

  • 格式一:
delete from 表名

该命令可以直接删除表中的全部数据

  • 格式二:
delete from 表名 where 条件

该命令可以删除表中的指定数据

直接举例子

现在有以下表student(如下图)

例子1.

删除student表中的sage为18的数据

delete from student where sage=18

看结果

删除三行,我们现在进表里看

例子二:

        删除表中所有数据

delete from student

老规矩,看结果

我们来看表

没数据了,说明命令执行成功下一个

但我们重新插入数据时会发现,主键不也是从0开始自增,而是在删除数据之前最高的主键开始增加

截断表

截断表,类似于我们超市开的小票,打出来一大堆东西,一撕,啪!全都没了,然后重新打印下一张小票继续从o开始。简单点来说,就是删除表中全部的数据,而且会截断表(id会重新开始自增)

格式
truncate 表名

老规矩,我们举例子来验证

上图为表sc的数据,主键为sid,我们来截断该表

TRuncate sc

ok,命令执行成功,接下来我们添加数据来看看

insert into sc (cid,score)values(1,20)

看结果

主键sid开始从零自增,完成!!

修改表中数据

也是有两种格式,

格式1:

update 表名 set 字段=值

该格式为批量修改,只要是该字段内的数据都会被修改

格式2:

update 表名 set 字段=值 where 记录=值

该字段用where进行条件筛选

话不多说直接举例:

现有表teacher,表内容如下图

例1:将阿斯顿修改为图灵

update teacher set tname="图灵" where tid=1

我们来查看表

阿斯顿已成功更改·下一个例子

例子二:

表中的tname修改为乔布斯

update teacher set tname="乔布斯"

查看表

修改表中数据就这些,完成!

9.3 对表中的字段进行操作

增加字段

在已经创建的字段之前或之后添加新的字段

格式一:在字段名之后添加新字段

alter table 表名 add column 新字段名 字段属性 after 字段名

格式二:在字段名之前添加新字段

alter table 表名 add column 新字段名 字段属性 first 字段名

直接举例:

teacher表如上图,在tname后添加新字段age,数据类型为int,默认为30

alter table teacher add column age int default"30" after tname 

我们查看表结构

ok,完成,我们开始下一个环节

删除字段:

顾名思义,删除字段,不做解释

格式:

alter table 表名 drop column 字段名

我们还是以上述表举例

例子

删除tname字段

alter table teacher drop column tname 

我们看下表

ok,删除表成功

注意:贸然删除字段可能会导致一些未知错误,因此:

建议不要删除!

建议不要删除!!

建议不要删除!!!

建议不要删除!!!!

建议不要删除!!!!!

建议不要删除!!!!!!

修改字段名

        修改字段名,见名知义,

格式:

alter table 表名 change column 字段名 新字段子 属性约束

 还是举例来看一下吧

还是那个teacher

例:

将字段名age修改为gae

alter table teacher change column age gae int(30)

我们来看结果

ok了,

该命令不仅可以修改字段名,也可以去修改数据类型和字段修饰。这里就不一一演示了。还请各位读者见谅。

修改字段顺序

这玩意跟之前添加字段还有些类似,还别不信,直接看格式
格式一:

alter table 表名 modify column 字段名 属性 after 位置

格式二:

alter table 表名 modify column 字段名 属性 first 位置

 这里我们还是举例表示:

还是teacher表,将表中的age字段移动至tid之前

alter table teacher modify column tid int(30) after gae

我们来看一下表

改过去了,说明ok,没问题对表中的字段进行操作就了解这么多,接下来进入下一个板块

9.4查询表中的内容

9.4.1 简单查询

就是可以查看表中的内容,这里我们先看格式,再去了解

格式

select 查询的内容 from 表名 where 条件

表示查询内容的方法有很多我们来看几个较为常用的

表示查询内容的方法:
  • *:表示所有的内容
  • 一个或者多个字段的名字:表示仅仅查询一个或者多个字段(查询多个字段的时候,多个字段之间,用逗号分割)

注意:查询内容只能通过字段查询相关记录,不能通过记录去查询,如果想要控制显示记录,则需要通过where之后加条件去执行。

where后条件写法

  • > 大于
  • >= 大于等于
  • < 小于
  • <= 小于等
  • <> 不等于
  • != 不等于
  • between ... and ... 判断范围
  • is null 是空
  • is not null 不是空
  • like 模糊查询

        (like后可能要跟通配符“%”,%  表示任意个任意字符,具体使用方法如下面例子)

  • in 判断某个字段是否在给定的集合中

好了,一条简单些的select语句大概就由这么些内容组成,之后的内容我们通过例题进行补充

例:

假设有一表name,如下

查询name中age大于20的字段

select *from name where age > 20

查询name中age大于等于20的字段

select *from name where age >= 20

查询name中age小于20的字段

select *from name where age < 20

查询name中age为空的字段

select *from name where age is null

查询name中age不为空的字段

select *from name where age is not null

查询name中age为3,5,7的字段

select *from name where age in(3,5,7)

 

查询name中 age大于等于8 且小于等于50
select *from name where age>3 and age < 50

注意:接下来就要用到简单查询了!!!!

简单查询如下

查询name中name包含a的记录

select name from name where name like "%a%"

查询name中namey以a为结尾的记录

select name from name where name like "%a"

(因为框中只有一个a,所以a即使开头也是结尾)

我们就先简单举上述这些例子,接下来我们对简单进行略微的扩展

   9.4.2查询排序

        就是对上述的结果进行了简单的排序,话不多说,我们先来看格式

格式:

select 查询内容 from 表名 where 条件 order by 字段名

排序分为两种字段名,

  • 升序(默认为升序)

        asc

  • 降序

        desc

看上去好像怪简单的,我们直接进行实操

还是以上面name为例

查询name中age不为空的字段并且对age由高到低进行排序

select *from name where age is not null order by age desc

查询name中age不为空的字段并且对name由低到高进行排序

select *from name where age is not null order by name asc

这里我们可以看到,当排序对象为数字时,是从0开始进行排序;当排序对象是字母时,则是依照字母顺序表从a到z进行排序。因此在排序时请注意这几点。

9.4.3 指定输出行

指定输出行,顾名思义就是指定输出前几行,其余记录不进行显示,老规矩,还是先看格式

格式:

select 查询内容 from 表名 where 条件 order by 字段名 limit 数字

当不使用limit字段时,默认输出所有符合条件的记录,而当使用该字段时,输入数字是几则显示几条记录。我们还是举例说明

例:

查询name中age不为空的字段并且对name由低到高进行排序显示前三条记录

select *from name where age is not null order by name asc limit 3

看结果

ok,下一个

9.4.4 聚合函数:

 可以简单理解为四则运算,但一般常用的聚合函数很少用到乘除法则,因此这里只讲常用的聚合函数,讲解不到位还请读者谅解0..0

常用的聚合函数:

  • sum() 求和
  • avg() 求平均值
  • max() 求最大值
  • min() 求最小值
  • count() 统计记录条数

格式:

select 聚合函数(字段名) from 表名

还是以上述name表为例,

简单举个例子:

计算所有学生年龄的和

select sum(agde) from name

计算所有学生年龄的平均值

select avg(age) from name

统计一共有多少条记录

select count(age) from name

统计最小的年龄

select min(age) from name

ok了,下一个

9.4.5 查询记录去重

顾名思义,就是去除重复字段,我们直接看格式

格式

select distinct 字段名 from 表名

例:

查询name中age不为空的字段并且对name由低到高进行排序并去除重复字段

select distinct age from name where age is not null

下一个

9.4.6 分组及分组后加条件

分组

对记录进行区分,通常用于统计过个字段人数使用

group by

格式:

select 字段 from 格式 group by 分组字段

直接举例,还是上个name表

对age进行分组,并显示名称

select name from name GROUP BY age

分组后加条件
having,使用格式如下
select 字段 from 表名 group by 字段 having 条件

因为该命令不常用,因此这里只做了解,还请各位读者谅解,还是通过例题来简单了解一下分组后加条件,例题如下

有一表students,内容如下

例题:通过gender进行分组分别查询查询students表中stuid大于二十的男生人数

select count(stuid),gender from students where stuid>20 group by gender  having gender="m"

我们来看结果

注:(分组后加条件是在分组后显示的结果进行进一步的条件筛选,若分组时结果没有条件,则会显示查询不到对应的字段或其他报错,因此在分组后查询过程中,建议先运行不分组后不加条件的代码,针对分组后不加条件的代码进行进一步的条件筛选!!!)

以上就是本期内容了,很多东西笔者因为篇幅原因还没讲到,还请各位见谅。如有错误,还请谅解.感谢各位观看!

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

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

相关文章

华为认证大数据是什么?华为认证大数据有用吗?

华为大数据是用来搜集整理大数据&#xff0c;提供解决方案的数据中心。华为大数据解决方案是华为公司推出的一种综合性云解决方案&#xff0c;主要针对广告营销、电商、车联网等大数据应用场景的云计算大数据方案&#xff0c;帮助企业用户构建大数据平台&#xff0c;解决企业的…

GRE over IPsec VPN实验

一、拓扑图 二、组网需求 某企业总部、分支1、分支2分别通过 R1&#xff0c;R3&#xff0c;R4 接入互联网&#xff0c;配置默认路由连通公网按照图示配置 IP 地址&#xff0c;R1&#xff0c;R3&#xff0c;R4 分别配置 Loopback0 口匹配感兴趣流&#xff0c;Loopback1 口模拟业…

GPIO输出速度(ARM-GD32)

单片机输出速度对GPIO硬件的影响 如果T为100ns 那么2/3*100ns 67ns 那么tr tf 38 ns &#xff08;也就是不能超过32ns&#xff09; tr 和tf和什么东西有关如何去控制 CL 是一个电容&#xff0c;电容会改变和影响电压变化的速率&#xff0c;输出高低电平也就是对电容进行充电…

【噪声学习】SELFIE:更新不干净样本的鲁棒性深度学习

SELFIE: Refurbishing Unclean Samples for Robust Deep Learning 摘要: 由于深度神经网络具有极高的表达能力,其副作用是即使在标签噪声极高的情况下也能完全记住训练数据。为了克服对噪声标签的过度拟合,我们提出了一种名为 SELFIE 的新型鲁棒训练方法。我们的主要想法是…

Python GUI开发- PyQt5 开发小工具环境入门

前言 常见的python开发gui的库有 Tkinter&#xff0c; PyQt5&#xff0c; wxPython等。本教程是选择PyQt5 开发桌面小工具。 环境准备 只需pip安装即可快速准备好开发环境 pip install pyqt5快速开始 创建一个空的window窗口 Qapplication()&#xff1a;每个GUI都必须包含…

【Linux】:文本编辑与输出命令 轻松上手nano、echo和cat

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Linux深造日志 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一、nano1.1 打开文件&#xff1a;1.2 常用快捷键&#xff1a;1.3 其他功能&#xff…

读人工智能时代与人类未来笔记03_演变

1. 演变 1.1. 每个社会都找到了属于自己的一套适应世界的方法 1.1.1. 适应的核心&#xff0c;是有关人类心智与现实之间关系的概念 1.1.2. 人类认识周围环境的能力 1.1.2.1. 这种能力通过知识获得&#xff0c;同时也受到知识…

【渲染数学-01】如何模拟静态流(上)

文章目录 一、说明二、摘要三、简介四、稳定的纳维-斯托克斯4.1 基本方程4.2 解决方法 一、说明 关于流体物质的仿真和模拟&#xff0c;需要流体理论方面的一般知识。我们这里从基本流体方程入手&#xff0c;详细解释如何实现流体仿真的每一个具体步骤。 二、摘要 构建类似流体…

详解pytorch中循环神经网络(RNN、LSTM、GRU)的维度

详解pytorch中循环神经网络&#xff08;RNN、LSTM、GRU&#xff09;的维度 RNNtorch.nn.rnn详解RNN输入输出维度 LSTMtorch.nn.LSTM详解LSTM输入输出维度 GRUtorch.nn.GRU详解GRU输入输出维度 三种RNN的示例 首先如果你对RNN、LSTM、GRU不太熟悉&#xff0c;可点击查看。 RNN …

python数据可视化:层次聚类热图clustermap()

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 python数据可视化&#xff1a; 层次聚类热图 clustermap() [太阳]选择题 请问关于以下代码表述错误的选项是&#xff1f; import seaborn as sns import matplotlib.pyplot as plt import n…

代码随想录—— 填充每个节点的下一个右侧节点指针(Leetcode116)

题目链接 层序遍历 /* // Definition for a Node. class Node {public int val;public Node left;public Node right;public Node next;public Node() {}public Node(int _val) {val _val;}public Node(int _val, Node _left, Node _right, Node _next) {val _val;left _…

开源的全自动生成视频文案、视频素材、视频字幕、视频背景音乐的AI项目

网址 https://github.com/harry0703/MoneyPrinterTurbo 只需提供一个视频 主题 或 关键词 &#xff0c;就可以全自动生成视频文案、视频素材、视频字幕、视频背景音乐&#xff0c;然后合成一个高清的短视频。 如果用来做视频&#xff0c;可以先收藏一下&#xff0c;值得本地…

51 单片机[2-1]:点亮一个LED

一、在 Keil5 中新建项目 打开 Keil5 &#xff0c;点击 Project —— new μVision Project 新建文件夹 KeilProject &#xff0c;以后的项目都在这个文件夹下&#xff0c;再建一个文件夹 2-1 点亮一个LED。在该文件夹下创建名为 Project 的文件&#xff0c;并保存。推荐起这…

Spring Boot:异常处理

Spring Boot 前言使用自定义错误页面处理异常使用 ExceptionHandler 注解处理异常使用 ControllerAdvice 注解处理异常使用配置类处理异常使用自定义类处理异常 前言 在 Spring Boot 中&#xff0c;异常处理是一个重要的部分&#xff0c;可以允许开发者优雅地处理应用程序中可…

复利效应(应用于成长)

应用 每个人在智力、知识、经验上&#xff0c;复利效应都一样&#xff0c;只要能积累的东西&#xff0c;基本上最终都会产生复利效应。 再来看一下复利公式&#xff1a;FP*(1i)^n P本金&#xff1b;i利率&#xff1b;n持有期限。在使用时&#xff0c;一定要注意4个限定条件&a…

AI图书推荐:ChatGPT等生成式AI在高等教育中的应用

自2022年11月以来&#xff0c;ChatGPT及其在高等教育各个层面的影响已成为所有教育对话的核心内容。Chan和Colloton所著的书籍是首批全面探讨ChatGPT与生成式人工智能&#xff08;GenAI&#xff09;在高等教育中应用及影响的作品之一。 该书深入研究了针对专业环境定制的AI素养…

基础学习-Git(分布式版本控制系统)

学习视频推荐 http://【黑马程序员Git全套教程&#xff0c;完整的git项目管理工具教程&#xff0c;一套精通git】 https://www.bilibili.com/video/BV1MU4y1Y7h5/?p5&share_sourcecopy_web&vd_source2b85bd9be9213709642d908906c3d863 1、Git环境配置 安装Git Git下…

wireshark_概念

ARP (Address Resolution Protocol&#xff09;协议&#xff0c;即地址解析协议。该协议的功能就是将IP地址解析成MAC地址。 混杂模式 抓取经过网卡的所有数据包&#xff0c;包括发往本网卡和非发往本网卡的。 非混杂模式 只抓取目标地址是本网卡的数据包&#xff0c;对于发往…

《控制系统实验与综合设计》综合四至六(含程序和题目)

1.电机模型辨识实验 1.1 实验目的 &#xff08;1&#xff09;掌握一阶系统阶跃响应的特点&#xff0c;通过实验加深对直流电解模型的理解&#xff1b; &#xff08;2&#xff09;掌握系统建模过程中参数的整定&#xff0c;体会参数变化对系统的影响&#xff1b; &#xff0…

单片机开发板上外设资源讲解

单片机开发电路板上简单外设 开发板上各基础外设LED灯按键&#xff1a;数码管介绍液晶屏矩阵键盘扫描的概念LED点阵屏实时时钟蜂鸣器存储器 温度传感器&单总线 开发板上各基础外设 LED灯 中文名&#xff1a;发光二极管 外文名&#xff1a;Light Emitting Diode 简称&…