MySQL数据的增删改查(一)

目录

新增(create)

插入单条记录

插入多条记录

查询(retrieve)

查询所有列

查询特定列

查询字段为表达式

别名

去重

排序

按单列排序

按多列排序

使用表达式或别名排序

排序NULL值

条件查询

比较运算符

逻辑运算符

基本查询

AND和OR

范围查询

BETWEEN AND

IN

模糊查询

NULL 的查询

分页查询

修改(update)

删除(delete) 


在本篇文章中,我们来学习 C(create 增加)R(retrieve 查询)U(update 更新)D(delete 删除),即 数据的增删改查

新增(create)

要想插入数据,我们首先得有数据表,因此,我们先创建一张学生表:

USE test;

DROP TABLE IF EXISTS student;  -- 若学生表已经存在,则删除
CREATE TABLE student(
    id INT,
    name VARCHAR(20),
    age INT,
    class VARCHAR(10)
);

 学生表已经创建好了

接下来,我们就可以往表中插入数据了

插入单条记录

语法:

INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);

全列插入(所有数据都插入)时,可以省略  (column1, column2, column3, ...)

insert into student values  (1, "张三", 18, "1班");

插入成功

其中,

Query OK:表示执行成功

1 row affected:表示操作影响了一行记录

(0.01 sec):表示执行时间

ERROR:表示操作失败,出现了错误

Column count doesn't match value count at row 1:描述了错误原因,列数量与第一行中的值数量不匹配

而若只插入指定列,就需要使用 (column1, column2, column3, ...),column 的数量必须和 value 的数量一致

insert into student (id, name, age) values (2, "李四", 19);

插入多条记录

语法:

INSERT INTO table_name (column1, column2, column3, ...) VALUES

        (value1_1, value2_1, value3_1, ...),
       (value1_2, value2_2, value3_2, ...),
       ...;

插入两条数据:

insert into student values
    (3, "王五", 18, "2班"), 
    (4, "赵六", 19, "1班"); 

 指定列插入两条数据:

insert into student (id, name, age)values

    (5, "一一", 18), 
    (6, "二二", 19); 

注意:

(1)插入的数据类型要与表中列的数据类型匹配

(2)插入数据时,列的顺序必须和 VALUES 中的顺序一致

(3)若表的列中有 NOT NULL 约束,必须提供这些列的值(除非有默认值) 

查询(retrieve)

查询所有列

语法:

select * from table_name;

我们查询刚才插入的所有数据:

由于 student 表中的数据不多,因此很快就将所有的数据都查询出来了,但是,当表中的数据很多时,此时查询所有数据就需要花费很多时间

由于 mysql 是 客户端服务器 结构的:

当查询的数据量很大时,select * from table_name 操作就会产生大量的硬盘 IO 和网络 IO,就可能把硬盘和网卡的带宽吃满,服务器就无法正常响应了,而若此时其他的客户端向服务器发送请求,服务器就无法响应数据,其他客户端就会认为服务器挂了

因此,通常情况下,并不建议使用 * 进行全列查询(查询的列越多,意味着需要传输的数据量越大)

查询特定列

语法:

SELECT column1 column2, ... FROM table_name;

注:指定列的顺序不需要安装定义表的顺序来 

示例:

我们查询 id 和 年龄:

select id, age from student;

查询字段为表达式

语法:

select expr, ... from table_name;

示例:

表达式中不包含字段:

select id, name, 20 from student;

表达式中包含一个字段: 

select  id, name, age + 20 from student;

 在查询出结果后,会将每一行带入表达式进行运算

当前的表达式查询,并没有修改服务器上硬盘存储的数据本体只是在查询结果的基础上进行运算,得到的是一个 临时表,当这个查询操作结束时,这里的数据(age + 20)也就没有了,数据库服务器硬盘内容不会有任何改变

为了方便进行后续演示,我们再创建一个 考试成绩表:

drop table if exists exam_result;
create table exam_result(
    id int,
    name varchar(10),
    chinese decimal(4,1),
    math decimal(4,1),
    english decimal(4,1)
);

-- 插入数据
insert into exam_result values
    (1, "一一", 80.1, 70.9, 90.0),
    (2, "二二", 60.9, 76.9, 90.5),
    (3, "三三", 70.3, 96.3, 83.4),
    (4, "四四", 83.7, 84.6, 75.3);

表达式中包含多个字段: 

select id, name, chinese + math + english from exam_result;

别名

上述 chinese + math + english 计算的是成绩总和,我们一般会选择使用 总分 进行表示,因此,我们就可以以 总分 作为计算结果的临时别名

别名(alias):用于为表或字段指定临时名称,以简化查询和提高可读性,别名在查询的执行结果过程中不会改变数据库中的实际表名或列名

语法:

SELECT column [AS] alias_name FROM table_name;

例如:

select id, chinese + math + english as '总分' from exam_result;

as 可以省略,即:

select id, chinese + math + english '总分' from exam_result;

去重

当某列中有重复记录时,我们就可以使用 DISTINCT 对其进行去重

例如:

select age from student;

 

 去重:

select distinct age from student;

 

排序

在 MySQL 中,可以使用 ORDER BY 来对查询结果进行排序,当没有使用 order by 子句时进行查询,返回的结果是未定义(无序)的

按单列排序

语法:

SELECT column1, column2 FROM table_name ORDER BY column_name [ASC|DESC];

其中,ASC 表示 升序,排序时默认是升序,因此可以省略;DESC 表示降序

例如:

对数学成绩进行降序排列:

select id, name, math from exam_result order by math desc;

对语文成绩进行升序排列:

select id, name, chinese from exam_result order by chinese;

按多列排序

 语法:

SELECT column1, column2 FROM table_name ORDER BY column1 [ASC|DESC], column2 [ASC|DESC];

按照多个列进行排序时,先按照第一个列排序,若第一个列出现值相同的情况,则按照第二个列排序,以此类推

例如:

按照学生的年龄进行降序排列,若年龄相同,则按照 id 进行升序排列:

select id, name, age from student order by age desc, id;

使用表达式或别名排序

例如:

查询学生考试总分,按照升序进行排列:

select id, name, chinese + math + english as total from exam_result order by total;

排序NULL值

null 数据参与排序时,视为比任何值都小,升序时出现在最上面,降序时出现在最下面

条件查询

当我们只需要查询特定的数据时,就可以使用 WHERE 进行条件查询,过滤数据,只返回满足特定条件的数据

在学习条件查询的语法之前,我们先来学习一些运算符

比较运算符

运算符说明
>, >=, <, <=大于,大于等于,小于,小于等于
=等于,NULL不安全,出现 NULL = NULL 时结果为 NULL
<=>等于,NULL安全,出现 NULL <=> NULL 时结果为 true
!=, <>不等于
BETWEND a AND b范围匹配,[a, b],若 a <= value <= b,返回 true
IN (option, ...)若是 option 中的任意一个,返回 true
IS NULL是 NULL
IS NOT NULL不是 NULL
LIKE模糊匹配,% 表示任意多个字符,_ 表示任意一个字符

逻辑运算符

运算符说明
AND多个条件必须都为 true,结果才为 true
OR任意一个条件为 true,结果都为 true
NOT条件为 true 时,结果为 false

 注意:

(1)WHERE 条件中可以使用表达式,但是不能使用别名

(2)AND 的优先级高于 OR,在同时使用且需要先执行 or 时,需要使用 ()  小括号包裹优先执行的部分

接下来,我们来学习如何进行条件查询

查询语法:

SELECT column1, column2 FROM table_name WHERE condition;

基本查询

例如:

查询年龄为 18 的学生:

select id, name, age from student where age = 18;

查询总分大于240的学生:

select name, chinese + math + english as '总分' from exam_result where chinese + math + english > 240;

 

查询英语成绩大于语文成绩的学生:

select name, chinese, english from exam_result where english > chinese;

AND和OR

查询 数学成绩高于80分 并且 语文成绩也高于80分 的同学:

select name, math, chinese from exam_result where math > 80 and chinese > 80;

 查询 数学成绩高于80分 或 语文成绩也高于80分 的同学:

select name, math, chinese from exam_result where math > 80 or chinese > 80;

观察 AND 和 OR 的优先级:

select name, chinese, math, english from exam_result where chinese > 80 or math > 80 and english > 80;

上述查询相当于:

mysql> select name, chinese, math, english from exam_result where chinese > 80 or (math > 80 and english > 80);

 若要先使用 OR,则需要加上 () 

select name, chinese, math, english from exam_result where (chinese > 80 or math> 80) and english > 80;

范围查询

BETWEEN AND

查询 数学成绩在 80 - 90 的同学:

select name, math from exam_result where math between 80 and 90;

IN

查询 id 为 1、3、4、9 的学生:

select id, name from exam_result where id in (1, 3, 4, 9); 

模糊查询

使用 LIKE 进行模糊查询

我们往 student 表中插入数据

insert into student (id, name, age) values (7, "张一一", 20), (8, "张二二", 17); 

 使用 _ 匹配任意一个字符

select name from student where name like '张_';

使用 % 匹配任意多个(包括 0 个)字符

select name from student where name like '张%';

 

NULL 的查询

通过 IS [NOT] NULL 查询 NULL 值 或 过滤 NULL 值

 查询班级已知的同学:

select name, class from student where class is not null;

查询班级未知的同学

 select name, class from student where class is null;

分页查询

语法:

SELECT ... FROM table_name [WHERE...] [ORDER BY  ... ] LIMIT  count;

SELECT ... FROM table_name [WHERE...] [ORDER BY  ... ] LIMIT offset, count;

SELECT ... FROM table_name [WHERE...] [ORDER BY  ... ] LIMIT count OFFSET offset;

 offset:开始的行号(行号从 0 开始)

count:返回的行数

当不指定 offset 时,默认从 0(也就是第一条记录)开始,若指定 offset ,则从 offset 开始,显示 n 条数据 

例如:

按照 id 进行分页,获取第一页3条数据:

select id, name from student limit 3;

按照 id 进行分页,获取第二页3条数据: 

select id, name from student limit 3, 3;

 按照 id 进行分页,获取第三页3条数据: 

select id, name from student limit 3 offset 6;

修改(update)

语法:

UPDATE table_name SET column1 = value1 [, column2 = value2] [WHERE condition] [ORDER BY condition] [LIMIT];

例如:

将 id 为 3 的学生的数学成绩修改为 87:

 update exam_result set math = 87 where id = 3;

将所有学生的语文成绩加上 5 分:

update exam_result set chinese = chinese + 5;

将总成绩倒数的同学英语成绩加上 10 分:

update exam_result set english = english + 10 order by chinese + math + english limit 1;

删除(delete) 

语法:

DELETE FROM table_name [ WHERE ...] [ ORDER BY ... ] [ LIMIT ... ];

例如:

删除 id 为 3 的学生数据:

delete from exam_result where id = 3;

删除总分最高的两名学生数据:

delete from exam_result order by chinese + math + english desc limit 2;

删除表中所有数据:

delete from exam_result; 

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

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

相关文章

【阿一网络安全】如何让你的密码更安全?(三) - 散列函数

散列函数 散列函数&#xff08;Hash Function&#xff0c;又称散列算法、哈希函数&#xff09;&#xff0c;是一种从任何一种数据中创建小的数字指纹的方法。 散列值 散列函数&#xff0c;把任意长的消息明文&#xff0c;压缩成摘要&#xff0c;使得数据量变小&#xff0c;将…

k8s 容忍和污点

文章目录 Taint作用在节点上&#xff0c;能够使节点排斥一类特定的Pod&#xff0c;也就是不能“兼容”该节点的污点的Pod。对应的Toleration作用在Pod上&#xff0c;意为容忍&#xff0c;也就是可以兼容某类污点。 给节点增加一个Taint也很简单&#xff0c;直接使用kubectl ta…

【PostgreSQL】安装及使用(Navicat/Arcgis),连接(C#)

简介 PostgreSQL 是一个功能强大的开源对象关系数据库系统 下载地址 PostgreSQL: Downloads 由于我电脑上安装的是arcgispro3.1所以需要下载对应的postgresql版本 PostgreSQL 12 对应的 PostGIS 版本主要是 3.5.0 或更高版本。 安装 一般设置为postgresql 安装扩展插件 此…

Centos如何配置阿里云的yum仓库作为yum源?

背景 Centos在国内访问官方yum源慢&#xff0c;可以用国内的yum源&#xff0c;本文以阿里云yum源为例说明。 快速命令 sudo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak sudo wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.a…

《深度学习》OpenCV轮廓检测 模版匹配 解析及实现

目录 一、模型匹配 1、什么是模型匹配 2、步骤 1&#xff09;提取模型的特征 2&#xff09;在图像中查找特征点 3&#xff09;进行特征匹配 4&#xff09;模型匹配 3、参数及用法 1、用法 2、参数 1&#xff09;image&#xff1a;待搜索对象 2&#xff09;templ&am…

【2025】基于python的网上商城比价系统、智能商城比价系统、电商比价系统、智能商城比价系统(源码+文档+解答)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

RTR_Chapter_4_中

四元数 四元数可以用于表示旋转和方向&#xff0c;它在很多地方都比欧拉角和矩阵表示更加优秀。任何三维方向都可以表示为一个绕特定轴的简单旋转&#xff0c;给定一个旋转轴和旋转角度&#xff0c;可以直接将其转换为一个四元数&#xff0c;或者是从一个四元数中提取出旋转轴和…

大数据与人工智能:脑科学与人工神经网络ANN

文章目录 大数据与人工智能&#xff1a;脑科学与人工神经网络ANN一、引言ANN简介研究背景与应用领域发展背景应用场景 二、ANN背后的人脑神经网络人脑神经网络的专业描述神经元的结构信号处理 思考和认知过程认知功能的实现 对机器学习算法的启示 三、ANN的研究进展初始阶段&am…

进程间通信-进程池

目录 理解​ 完整代码 完善代码 回收子进程&#xff1a;​ 不回收子进程&#xff1a; 子进程使用重定向优化 理解 #include <iostream> #include <unistd.h> #include <string> #include <vector> #include <sys/types.h>void work(int rfd) {…

Amazing!精准可控新视角视频生成+场景级3D生成!北大港中文腾讯等开源ViewCrafter

论文链接: https://arxiv.org/abs/2409.02048 GitHub链接&#xff1a;https://github.com/Drexubery/ViewCrafter 项目链接: https://drexubery.github.io/ViewCrafter/ Demo链接: https://huggingface.co/spaces/Doubiiu/ViewCrafter 亮点直击 本文提出了一种迭代视图合成策略…

java设计模式(持续更新中)

1 设计模式介绍 设计模式代表了代码的最佳实践&#xff0c;被有经验的开发人员使用。设计模式是很多被反复使用并知晓的&#xff0c;主要是对代码和经验的总结。使用设计模式是为了重用代码&#xff0c;并让代码更容易被人理解&#xff0c;保证代码的可靠性。对接口编程而不是…

双向dfs,多次dfs

前言&#xff1a;这个答案给我们提供了一种多次dfs的思路&#xff0c;记录queue的size&#xff0c;每次只取size个&#xff0c;就刚刚好只处理了上一次的‘ 题目地址 #include<bits/stdc.h> using namespace std;//定义队列节点 struct node {int x,y; }rear,front; //Q[…

JVM 调优篇2 jvm的内存结构以及堆栈参数设置与查看

一 jvm的内存模型 2.1 jvm内存模型概览 2.2 pc计数器 它是一块很小的内存空间&#xff0c;集合可以忽略不记&#xff0c;也是运行速度最快的存储区域。不会随着程序的运行需要更大的空间。 在jvm规范中&#xff0c;每个线程都有它自己的程序计数器&#xff0c;是线程私有的&…

二、栈和队列-算法总结

文章目录 二、栈和队列2.1 基本应用2.1.1 逆波兰表达式求值2.1.2 有效的括号 2.2 单调栈2.2.1 柱状图中最大的矩形 二、栈和队列 2.1 基本应用 2.1.1 逆波兰表达式求值 150. 逆波兰表达式求值 class Solution {/**思路分析&#xff1a;遇到数则压栈&#xff0c;遇到运算符…

【深度学习】线性回归的从零开始实现与简洁实现

前言 我原本后面打算用李沐老师那本《动手学深度学习》继续“抄书”&#xff0c;他们团队也免费提供了电子版(https://zh-v2.d2l.ai/d2l-zh-pytorch.pdf)。但书里涉及到代码&#xff0c;一方面展示起来不太方便&#xff0c;另一方面我自己也有很多地方看不太懂。 这让我开始思…

Arm GIC-v3中断原理及验证(通过kvm-unit-tests)

一、参考连接 gic-v3相关原理可参考https://zhuanlan.zhihu.com/p/520133301 本文主要通过开源测试工具kvm-unit-tests&#xff0c;针对GIC的中断进行一系列验证&#xff0c;这样可以直入中断底层&#xff0c;熟悉整个原理。 kvm-unit-tests官网为kvm-unit-tests / KVM-Unit…

labview禁用8080端口

需求背景 最近电脑上安装了labview全家桶,发现idea的8080端口项目启动报错,一直提示8080端口被占用。最简单的办法就是找到8080端口的服务,然后关闭这个服务。但是我不想这么做,我想把labview的web服务器的端口给修改了。 操作教程 1、cmd查看8080端口 2、windows进程 同…

022.PL-SQL进阶—分页过程

课 程 推 荐我 的 个 人 主 页&#xff1a;&#x1f449;&#x1f449; 失心疯的个人主页 &#x1f448;&#x1f448;入 门 教 程 推 荐 &#xff1a;&#x1f449;&#x1f449; Python零基础入门教程合集 &#x1f448;&#x1f448;虚 拟 环 境 搭 建 &#xff1a;&#x1…

Flask 实现用户登录功能的完整示例:前端与后端整合(附Demo)

目录 前言Demo 前言 对于python用户的登录&#xff0c;以下只是提供一个Demo用于学习 更多的python知识点可从我的专栏中进行学习 python专栏详细分析Flask中的蓝图Blueprint&#xff08;附Demo&#xff09;详细分析Flask部署云服务器&#xff08;图文介绍&#xff09;构建F…

2024 年 GitLab Global DevSecOps 报告解读

近日 GitLab 正式发布了 2024 年 GitLab Global DevSecOps 报告&#xff0c;报告主题为 What’s next in DevSecOps。在全球有超 5000 位 IT 人员参与了该报告的调研&#xff0c;超 70% 为企业管理者&#xff0c;50% 以上的受访者所在企业规模超过 500人。该报告深刻揭示了在 A…