iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL | 数据库的管理和操作【表的增删改查】
  • 872
分享到

MySQL | 数据库的管理和操作【表的增删改查】

1024程序员节mysql数据库 2023-10-27 12:10:44 872人浏览 独家记忆
摘要

Mysql | 数据库的管理和操作【表的增删改查】 系列文章目录 第一章:MySQL | 数据库的管理和操作(基本介绍) 第二章:MySQL | 数据库的基本操作和表的基本操作 第三章:mysql |

Mysql | 数据库的管理和操作【表的增删改查】

系列文章目录

第一章:MySQL | 数据库的管理和操作(基本介绍)

第二章:MySQL | 数据库的基本操作和表的基本操作

第三章:mysql | 数据库的表的增删改查

文章目录

本节目标

  • CRUD : Create, Retrieve,Update,Delete

  • 新增数据

  • 查询数据

  • 修改数据

  • 删除数据

  • 注释:在sql中可以使用“–空格+描述”来表示注释说明

  • CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写。

一、新增(Create)

语法:

INSERT [INTO] table_name [(column [, column] ...)]  VALUES (value_list) [, (value_list)] ...value_list: value, [, value] ...

案例:

insert into student valuse (1,'张三');

在这里插入图片描述

  • 这里的个数,类型,顺序和表头结构匹配
  • SQL没有字符类型,‘’“”都可以表示字符串
  • 这里数据库在插入的有的时候是报错,这是因为在数据库不做任何修改,默认情况下创建数据库的字符集是拉丁文字符集,不能表示中文

在这里插入图片描述

  • 此时我们要做的事情就是让我们的数据库,字符集和你输入的时候设置生utf-8
create database test charset utf8;

在这里插入图片描述

  • 现在就可以了,一般来说,我们的终端是utf8的,但是有的同学是gbk的;
  • 其中utf8正常保存数据是没事的,带上表情,就有可能出错了,而utf8mb4是更完整的utf8

在这里插入图片描述

指定列插入 + 全列插入

  • 插入两条记录,value_list 数量必须和指定列数量及顺序一致
insert into student (name,gender) values('张三','男');

在这里插入图片描述

此时:values后面的内容就是和前面的()的内容匹配

  • 要想看到结果,就要使用查询语句,
  • 可以看到,id是空着的,别的都有,这就是指定列插入
  • 这里的这个语句下面详细介绍
select * from student;

在这里插入图片描述

多次插入

  • 这里也可以一次性插入多条数据,那就是一次插入
insert into student values(2,'李四','男'),(3,'王五','男');
  • 一次插入n个记录,比一次插入一个数据,分n次插入,效率要高

在这里插入图片描述

时间日期类型,数据的插入

create table homework (id int ,creatTime datetime);

在这里插入图片描述

  • 插入时间的时候,是通过特定格式的字符串来表示时间日期的,如‘2023-02-17 21:25:00’
insert into homework values(1,'2023-02-17 21:25:00');

在这里插入图片描述

  • 那么我现在就想把这个时间日期设置成当前时刻,咋办?sql提供了一个特殊的函数,now()
insert into homework values(1,now());

在这里插入图片描述

二、查询(Retrieve)

全列查找

全列查找(查找整个表的所有行,所有列)

select * from 表名
  • 这里面的*表示所有的列,这种特殊含义的符号,计算机中叫做【通配符】

在这里插入图片描述

  • 但是这里执行select *操作,肯会非常危险
  • 如果数据量就几百几千,就没有什么事,如果数据量有几亿,几十亿select *操作就很麻烦了,这个操作会瞬间吃满硬盘带宽和网络带宽,就可能导致其他程序无法使用硬盘或者使用网络

那么怎么办呢?有办法吗?有的!

当你需要操作的时候,一定要拉上一个人和你一起操作O(∩_∩)O哈哈~

指定列查询

-- 指定列的顺序不需要按定义表的顺序来 select 列名,列名...from 表名;
  • 我们需要哪些列就查询哪些列
select name,gender from student;

在这里插入图片描述

表达式查询

  • 查询过程中,可以做一些简单的运算~~
  • 这个是进行之间的运算
create table exam_result (id int,name varchar(20),chinese decimal(3,1),math decimal(3,1),english decimal(3,1));

在这里插入图片描述

insert into exam_result (id,name,chinese,math,english) values (1,'唐三藏', 67, 98, 56), (2,'孙悟空', 87.5, 78, 77), (3,'猪悟能', 88, 98.5, 90), (4,'曹 孟德', 82, 84, 67), (5,'刘玄德', 55.5, 85, 45), (6,'孙权', 70, 73, 78.5), (7,'宋公明', 75, 65, 30);

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

  • 接下来就看看查询字段为表达式
  • 可以在查询的时候,针对分数进行变换;比如让查询的math成绩都在原来的基础上 + 10分;
select name,math + 10 from exam_result;

在这里插入图片描述

  • 这个结果都是在原有的分数上 + 10的

  • 上述这样的查询,数据库服务器硬盘的数据,是否发生了改变?

  • 如果我们再次查询math,此时的结果是 + 10之前的还是 + 10之后的呢?

我们再次操作一下~~

在这里插入图片描述
小结一下:

  • 我们要要牢记一句话,mysql是一个“客户端-服务器”结构的程序!!!
  • 用户在客户端输入的sql,通过请求发送给服务器,服务器解析并执行sql,把查询的结果从硬盘读取出来,通过网络响应还给客户端,客户端把这些数据以临时表的形式展现出来
  • 这只是在客户端这里显示一下临时表,和服务器那边的硬盘上的表没啥关系

我们还可以查看总成绩,那么怎么查看呢?接着往下看~~

select name,math + chinese + english from exam_result;
  • 表达式查询是让列和列之间进行运算而不是行和行之间

在这里插入图片描述
后面还会学一个聚合查询,是行和行之间的运算~~


在这里插入图片描述

这就引出了一个查询的时候指定别名~~

指定别名查询

  • 指定别名,就相当于是 起了个“小名”更方便的来理解含义
  • 我们可以使用as关键字来查询
  • 下面进行演示:
select name,math + chinese + english as total from exam_result;
  • 可以看到,我们查询出来的名字发生了变化~~

在这里插入图片描述

  • 其中 as可以省略,但是不建议~~

去重

  • 我们可以使用distinct关键字进指定列进行去重,把重复的行只保留一个
  • 接着看~~
select distinct math from exam_result;

在这里插入图片描述

  • distinct指定多个列的时候,要求这些列的值都相同,才视为重复

查询结果排序

  • 使用了order by子句,指定某些列进行排序~~,排序可能是升序,也可能是降序

  • order by 是可以根据多个列进行排序~~

  • 比如说按照数学成绩进行升序排序

select name,math from exam_result order by math;

在这里插入图片描述

  • 对于MySQL来说,如果一个sql没有指定order by此时查询的结果的顺序,是不可预期的

  • 代码逻辑中,不能依赖这里的查询顺序的

刚刚是升序排序的,那么怎么降序排序呢?只需要在后面加上desc就可以了

select * from exam_result order by math desc;

在这里插入图片描述

  • 此处的descdescend单词的缩写,不是describe

  • 还可以使用asc表示升序排序,但是省略不写默认就是升序

  • 还可以指定多个列来排序,多个列之间使用来分割 ,这个列越靠前,就是越关键的排序依据~~

  • 先按照第一列排序,如果第一列的值相同了,再按照第二列排序

select * from exam_result order by math desc,chinese desc;

在这里插入图片描述

条件查询

在查询的时候指定筛选条件

  • 需要先描述条件,怎么描述条件呢?
  • sql通过一系列的运算符来表示条件~~

比较运算符:

在这里插入图片描述

逻辑运算符:

在这里插入图片描述

  • 通过where子句,再搭配上条件表达式,就可以完成条件查询~~
select * from exam_result where english < 60;
  • 我们来看一下

在这里插入图片描述

  • 其中的where english < 60相当于针对数据库的表进行遍历,取出每一行数据,把数据代入条件中,看条件是否符合
  • 如果是,这个记录就保留,作为结果集的一部分
  • 如果是 假,这个记录就pass,下一条继续~~

在这里插入图片描述

  • 条件查询,可以直接拿两个列进行比较~~
select * from exam_result where chinese > english;

在这里插入图片描述

  • 这里和上面的where english < 60一样,都是取出每一行数据,把数据代入条件中,看条件是否符合

在这里插入图片描述

  • 条件查询,可以使用表达式来作为条件
select * from exam_result where chinese + english + math < 200;

在这里插入图片描述

  • 这样写是不是不明显,那我们还可以下面这样写
select name,chinese+math+english from exam_result where chinese + english + math < 200;

在这里插入图片描述

  • 这样写是不是更加直观~~
  • 还记得吗?有一个as的关键词~~
  • 那么是不是可以下面这样写?
select name,chinese + math + english as total from exam_result where total < 200;

在这里插入图片描述

  • 可以看到是报错了~~
  • 在上面的代码中,写下一个sql,不是从前往后的执行,执行顺序是有特定的规则的
    执行规则:
  1. 遍历每一行
  2. 把这一行代入where的条件中
  3. 符合条件的结果,再根据select这里指定的列,再进行查询/计算

注意:

此处的total别名不能作为where条件,和当前sql的执行顺序有关,当然,这也是mysql对于语法规定的一部分~~

  • 所以只能写成原有的表达式~
select name,chinese + math + english as total from exam_result where chinese + math + english < 200;

在这里插入图片描述


在这里插入图片描述

select * from exam_result where chinese > 80 and english > 80;

在这里插入图片描述


在这里插入图片描述

select * from exam_result where chinese > 80 or english > 80;

在这里插入图片描述


  • 如果一个where中既存在and有存在or,那么它们的优先级是先执行and后执行or

范围查询

BETWEEN … AND …

  • 约定的一个前闭后闭区间(包含两侧边界)

在这里插入图片描述

select * from exam_result where chinese >= 80 and chinese <= 90;

在这里插入图片描述

  • 或者也可以写成下面的代码,这两种写法本质上是一样的~~
select * from exam_result where chinese between 80 and 90;

在这里插入图片描述


在这里插入图片描述

select * from exam_result where math = 58 or math = 59 or math = 98 or math = 99;

在这里插入图片描述

  • 或者也可以这样写:
select * from exam_result where math in(58,59,98,99);

在这里插入图片描述


模糊查询

like
  • 模糊匹配,不要求元素完全相同,只要满足一定的规则就可以了

  • like 功能比正则表达式简单的多,

只支持两个用法:

  1. 使用%代表任意0个字符或者N个字符
  2. 使用_代表任意1个字符
  • 列如:
  • 查询姓孙的同学
select * from exam_result where name like '孙%';

在这里插入图片描述

  • 可以看到查询出来了,列如用_来模糊查找:

在这里插入图片描述

  • 还可以下面这样写~~
  • like '%孙'查询结尾的
  • like'%孙%'查询包含孙的

  • mysql效率比较低的,很容易称为性能瓶颈,模糊匹配更是比较低效的写法,如果这里支持的功能更复杂,反而更拖慢数据库的效率~~
  • 使用数据库,就算优化出来,也达不到要求,我们的做法是不用数据库,数据都放在内存中搜索~~

NULL 的查询

我们要想查询为空(null)的值,那么怎么查询吗?是下面这样吗?

select * from exam_result where chinese = null;

在这里插入图片描述

为什么会出现这样的情况?

  • null和其他数值进行运算,结果还是null;
  • null结果在条件中,想当于false
  • 所以null = null 结果等于null --> false;

针对这样的问题怎么解决呢?

  • 在sql里提供了这样的一个比较相等的<=>,使用这个比较相等运算,就可以处理null的比较~
  • 可以看到就可以查询成功了
select * from exam_result where chinese <=> null

在这里插入图片描述

  • 或者也可以下面这样写,对空值进行判定~~
select * from exam_result where chinese is null;

在这里插入图片描述


分页查询

这里所用到的关键字是limit

select * from exam_result limit 3;
  • 可以看到后面这里加上3,就是只显示3条

在这里插入图片描述

  • limit还可以搭配offset,声明从那一条开始查询(从0开始计数)
  • 下面进行代码演示~~
select * from exam_result limit 3 offset 3;

在这里插入图片描述

  • 还有一种写法:limit 3 offset 6等价于 limit 6,3

  • 这种写法不太推荐,很容易混淆~~

  • limit 这个东西是可以和前面的那些查询搭配使用的~~

列如:查询总分前三名的同学的信息:

  1. 计算每个同学的总成绩(表达式)
  2. 按照成绩排序(降序)
  3. 取前三条记录

代码操作:

select name,chinese + english + math as total from exam_result order by total desc limit 3;
  • 注意这里的order by是可以使用别名的

在这里插入图片描述

查询基础部分暂时告一段落~~


三、修改(Update)

update 表名 set 列名 =... where 条件;

  • 我们接着看练习
    在这里插入图片描述
update exam_result set math = 80 where name = '孙悟空';

在这里插入图片描述

  • 我们再进行查看,可以看到已经修改成功了~~

在这里插入图片描述


在这里插入图片描述

update exam_result set math = 60 ,chinese = 70 where name = '曹孟德';

在这里插入图片描述


在这里插入图片描述

select name, chinese + math + english  as total from exam_result  order by total desc;
  • 首先我们查看有哪些同学是倒数三名的~~
  • null在排序的时候,视为最小的值~~

在这里插入图片描述

  • 然后我们接下来再进行将总成绩倒数前三的 3 位同学的数学成绩加上 30 分
update exam_result set math = math + 30 order by chinese + math + english asc limit 3;
  • 如果要加的的数字超出范围了,就会报错,原来的成绩不会修改

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

  • 我们加上10应该就不会报错了~~
update exam_result set math = math + 10 order by chinese + math + english asc limit 3;
  • 可以看到,已经加成功了~~

在这里插入图片描述


在这里插入图片描述

  • 这里如果要改成两倍的话,就会超出范围,我们就修改成0.5倍~
update exam_result set chinese = chinese / 2;

在这里插入图片描述

  • 我们这里可以查看警告
show warnings;

在这里插入图片描述

  • 其中里面的truncated意思就是截断!
  • 小数点后位数不够了,只能截断了~

  • 这两个成绩已经是截断后的成绩了~~

在这里插入图片描述

四、删除(Delete)

delete删除记录(行)

delete from 表名 where 条件;
  • 删除姓孙的考试成绩

下面进行代码演示:

delete from exam_result where name like '孙%';
  • 这里就是把条件匹配出来的结果,都删掉了!!

在这里插入图片描述

  • 那么有同学说表名后面不加条件,会不会里面的内容都会删除?会的!!!
delete from exam_result;
  • 可以看到已经全部删除了,这个操作基本相当于删表!!!

在这里插入图片描述

所以delete操作也是非常危险的!!!


学习完上面的操作,那么增删改查都是什么呢?

  • 增:insert into 表名...
  • 删:delete from 表名...
  • 改:update 表名...
  • 查:select from 表名...

内容重点总结

  • 新增:
-- 单行插入insert into(字段1, ..., 字段N) values (value1, ..., value N);-- 多行插入insert into(字段1, ..., 字段N) values(value1, ...),(value2, ...),(value3, ...);
  • 查询
-- 全列查询select * from-- 指定列查询select 字段1,字段2... from-- 查询表达式字段select 字段1+100,字段2+字段3 from-- 别名select 字段1 别名1, 字段2 别名2 from-- 去重DISTINCTselect distinct 字段 from-- 排序ORDER BYselect * fromorder by 排序字段-- 条件查询WHERE:-- (1)比较运算符 (2)BETWEEN ... AND ... (3)IN (4)IS NULL (5)LIKE (6)AND (7)OR (8)NOTselect * fromwhere 条件
  • 修改
updateset 字段1=value1, 字段2=value2... where 条件
  • 删除
delete fromwhere 条件

好了,数据库的管理和操作【表的增删改查】初阶就到这里结束了,后面我们还有进阶,感谢大家的收看,觉得有用的话三连一下吧~~🌹🌹🌹

来源地址:https://blog.csdn.net/2201_76004325/article/details/133919170

您可能感兴趣的文档:

--结束END--

本文标题: MySQL | 数据库的管理和操作【表的增删改查】

本文链接: https://www.lsjlt.com/news/491594.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL | 数据库的管理和操作【表的增删改查】
    MySQL | 数据库的管理和操作【表的增删改查】 系列文章目录 第一章:MySQL | 数据库的管理和操作(基本介绍) 第二章:MySQL | 数据库的基本操作和表的基本操作 第三章:MySQL |...
    99+
    2023-10-27
    1024程序员节 mysql 数据库
  • MySQL库和表的操作(DDL) 和 数据增删改(DML)
    文章目录 💒创建和管理表🚏 基础知识🚀 一条数据存储的过程🚄 标识符命名规则🚒 MySQL中的数据类型 &...
    99+
    2023-09-01
    mysql sql java db sqlyong
  • MySQL表的CURD操作(数据的增删改查)
    目录一、SQL语句二、 基础表操作- 创建表- 查看库中的表- 查看表结构- 删除表- 重命名表三、mysql 中的增删查改操作- 增加(insert语句)- 查询(select语句)- 修改(update)-...
    99+
    2023-02-14
    mysql curd mysql表curd mysql表增删改查语句
  • MySQL表的操作『增删改查』
    ✨个人主页: 北 海 🎉所属专栏: MySQL 学习 🎃操作环境: CentOS 7.6 阿里云远程服务器 🎁软件版本: MySQL 5.7.44 文章目录 1.创建表1.1...
    99+
    2023-12-22
    mysql 数据库
  • django_数据库操作—增、删、改、查
    增加 增加数据有两种方法 1> sava >>> from datetime import date >>> book = BookInfo( btitle='西游记', bpub...
    99+
    2023-01-31
    操作 数据库
  • 【MySQL学习】MySQL表的增删改查操作
    文章目录 前言一、Create操作1.1 单行数据全列插入1.2 多行数据指定列插入1.3 插入更新1.4 插入替换 二、Read操作2.1 SELECT 操作2.1.1 全列查询2.1....
    99+
    2023-09-21
    mysql 学习 数据库
  • Python FastAPI 框架 操作Mysql数据库 增删改查
    2 比 1 更容易理解,可以先看2(单文件级别) 1、FastAPI 框架 操作Mysql数据库(项目多文件级别) FastAPI 可以使用任何您想要的关系型数据库。 在这里,让我们看一个使用着SQ...
    99+
    2023-09-06
    数据库 python fastapi
  • PHP+MySQL怎么实现数据库的增删改查操作
    PHP和MySQL是现代Web开发中最流行的技术。通过使用这两种技术,开发者可以构建动态Web应用程序,其中包括数据存储和检索。本文将介绍如何使用PHP和MySQL实现数据库的增删改查操作。一、环境配置在开始之前,我们需要确认已经配置好了P...
    99+
    2023-05-14
    php mysql 数据库
  • PHP+MySQL如何实现数据库的增删改查操作
    今天小编给大家分享一下PHP+MySQL如何实现数据库的增删改查操作的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、环境配...
    99+
    2023-07-05
  • Mysql 数据库表如何增删改查
    这篇文章将为大家详细讲解有关Mysql 数据库表如何增删改查,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、表操作1、【增加】 create table ...
    99+
    2024-04-02
  • SQLite数据库增删改查怎么操作
    在SQLite数据库中,可以使用SQL语句来进行数据的增删改查操作。 插入数据: 要插入数据,可以使用INSERT INTO语句,...
    99+
    2024-04-09
    sqlite
  • Mysql 数据库增删改查
    MySQL是目前最流行的关系型数据库。以下是MySQL数据库的增删改查操作。 1.数据库连接 在进行增删改查操作之前,需要先连接MySQL数据库。使用以下命令进行连接: import mysql.connectormydb = mysql....
    99+
    2023-08-31
    数据库 mysql oracle
  • Python3 数据库增删改查简单操作
    1,使用Python增加一个表#导入用来操作数据库的模块import pymysql#建立连接数据库对象conn=pymysql.connect(host='127.2.2.2',user='root',p...
    99+
    2024-04-02
  • 【MySql】数据库的CRUD(增删查改)
    写在最前面的话         哈喽,宝子们,今天给大家带来的是MySql数据库的CRUD(增删改查),CRUD是数据库非常基础的部分,也是后端开发日常工作中最主要的一项工作,接下来让我们一起进入学习吧,感谢大家的支持!喜欢的话可以三连...
    99+
    2023-09-08
    数据库 mysql sql
  • 聊聊node怎么操作MySQL数据库(增删改查)
    设置字段完成之后,点击上图左上角所示的保存按钮,就会进一步弹出对话框,让填写表的名字。我们填入user编辑字段添加数据一条内容输入完成后,按下tab,会自动进入下一条记录的输入学习使用SQL语句结构化查询语言(Structured Quer...
    99+
    2023-05-14
    数据库 MySQL Node.js
  • MySQL数据库中怎么实现增删改查操作
    本篇文章为大家展示了MySQL数据库中怎么实现增删改查操作,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、向所有字段插入2、向指定字段插入二、修改数据当然,我们也...
    99+
    2024-04-02
  • PandasDataFrame操作数据增删查改
    目录一、DataFrame数据准备二、增删改查操作1,增2,查3,改4,删一、DataFrame数据准备 增、删、改、查的方法有很多很多种,这里只展示出常用的几种。 参数inplac...
    99+
    2024-04-02
  • PHP怎么实现数据库的增删改查操作
    数据库的增删改查是Web开发的基本操作之一,PHP作为一种强大的Web后端开发语言,也有非常便捷的操作数据库的方式。在这篇文章中,我们将介绍如何使用PHP来实现数据库的增删改查操作。一、连接数据库在PHP中,连接数据库是必不可少的一步。我们...
    99+
    2023-05-14
  • 怎么用php操作数据库(增删改查)
    PHP是一种非常流行的Web编程语言,它的特点是简单易学,可以用来创建动态网站和Web应用程序。而其中最常见的操作就是只增删改查(CRUD),本文将详细介绍PHP中的这些操作。增加数据在PHP中,添加数据通常是通过向数据库中插入一行新数据来...
    99+
    2023-05-14
    php 数据库
  • MySQL的增删改查操作详解
    MySQL是一种功能强大且广泛使用的关系型数据库管理系统,它提供了一系列的增删改查(CRUD)操作,使得我们可以轻松地对数据库进行数据的读写和管理。 本文将详细介绍MySQL的增加(INSER...
    99+
    2023-10-02
    mysql 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作