初始MYSQL数据库(2)——创建、查询、更新、删除数据表的相关操作
找往期文章包括但不限于本期文章中不懂的知识点:
个人主页:我要学编程(ಥ_ಥ)-CSDN博客
所属专栏: MYSQL
前面我们学习了创建、删除数据库以及创建、查看、删除数据表的相关操作。 我们知道数据库中所存储的数据其实就是数据表中一条一条的记录。但是我们在创建数据表时,其没有存放任何数据。因此今天我们就来学习如果在数据表中存储数据记录,以及查看、删除等操作。
对数据表的一系列操作,我们称之为CRUD,即增删改查。
C - Create(增加);R - Retrieve(查询);U - Update(更新);D - Delete(删除)
目录
新增(Create)
查询(Retrieve)
修改(Update)
删除(Delete)
新增(Create)
新增其实就是插入数据。其对应的语法是:
INSERT INTO table_name (column1, column2, column3, ...)
VALUES (value1, value2, value3, ...);
参数说明与注意事项:
1、table_name是你要插入数据的表的名称;
2、column1,column2,column3,..是表中的列名,也就是字段(属性);
3、value1,value2,value3,..是要插入的具体数值,与列名的顺序是相对应的;
4、如果要插入的数据是字符型,必须使用单引号 引起数据。
5、如果我们要插入所有列的数据,可以省略列名;否则,就得指定列名插入;
6、插入数据时,也可以同时插入多条数据。
代码演示:
insert into books (name, author, price, sort)
values ('大话数据结构', '程杰', 59, '计算机');
注意:如果我们数据库的编码集使用的是Latin1 的话,就不能写入中文。要么将配置文件中的数据库服务的编码集改成 utf8mb4;要么在创建数据库时,将编码集设置成 utf8mb4。
插入完成之后,我们可以进行查询操作,来观察插入的数据是否符合我们的要求。
查询(Retrieve)
语法:
SELECT column1, column2, ...
FROM table_name
[WHERE condition]
[ORDER BY column_name [ASC | DESC]]
[LIMIT number];
参数说明与注意事项:
1、column1,column2,..是你想要查询的列的名称,如果使用*表示查询所有列。这里查询的结果也可以是一个表达式;
2、table_name 是你要查询的数据的表的名称;
3、WHEREcondition 是一个可选的子句,用于指定过滤条件,只返回符合条件的行。意思就是说这里是用来筛选数据的条件语句,可写可不写;
4、ORDER BY column_name[ASC」DESC]是一个可选的子句,用于指定结果集的排序顺序,默认是升序(ASC)。这里是对我们查询的结果集进行排序,默认情况下是升序(不写),即ASC,降序是DESC;
5、LIMIT number 是一个可选的子句,用于限制返回的行数。即分页查询;
6、DESC在SQL语句中有两个意思。一个是表示查询表的结构;另一个是表示降序排序 ;
7、分页查询是在查询结果过多时,将查询结果分成多页返回,并允许用户通过翻页来查看完整数据的一种查询方式。如下所示:
8、 也可以为查询的列名起一个简单易懂别名,这样在返回的查询结果中也是别名;
9、在查询的结果中,可能会出现重复的数据行,如果想要去除的话,可以加上一个关键字:DISTINCT。如果DISTINCT关键字后面有多个列名,只有当这些列名对应的数据都相同时,才能被看做是一组相同的数据。
10、WHERE条件可以使用表达式,但不能使用别名。这里我们就得来学习SQL语句中的执行顺序了。如下所示:
那有的小伙伴就会想到:既然在select子句中不能写,那么我在where子句中写不就行了吗?这里就违反了SQL的语法了。语法规定:别名只能在select子句中命名。
代码演示:
select * from books; -- 查询books表中所有的数据记录select name from books; -- 指定查询name这一列select chinese + english + math from score; -- 查询chinese+english+math的总成绩-- 查询chinese+english+math的总成绩并为其起一个别名总成绩
-- as 也是可以省略的,后面的字符串如果中间没有空格隔开的话,也是可以不加单引号的
select chinese + english + math as '总分' from score; -- 这里的是一个数据行的不同列相加-- 查询name为大话数据结构的全部信息
select * from books where name = '大话数据结构';select distinct name from books; -- 查询不同名字的书籍select price from books order by price asc; -- 将书籍的价格按照升序的结果排列-- 限制查询的结果一次只显示5条记录
select price from books order by price asc limit 5;
-- 下面的写法也和上面的写法效果是一样的-- 0 表示从第0条记录开始,5 表示一次性显示5条记录(这个可以跳着显示)
select price from books order by price asc limit 0, 5;
-- offset 表示偏移量,也就是从哪条记录开始,5 表示一次性显示5条记录(也可以跳着显示)
select price from books order by price asc limit 5, offset 0;
注意:在排序数据时,当有一列中出现了NULL时,这个NULL视为比任何值都要小。即升序是在最上方,降序是在最下方。
在进行where的条件查询时,可能还需要用到下面这些比较运算符和逻辑运算符等。
比较运算符
运算符 | 说明 |
> >= < <= | 大于,大于等于,小于,小于等于 |
= | 等于,NULL不安全,就是说 NULL = NULL的结果是NULL |
<=> | 等于,NULL安全,就是说NULL <=> NULL的结果是TRUE |
!= <> | 不等于 |
BETWEEN n0 AND n1 | 范围匹配,[a0,a1],如果 a0 <= value <= a1,返回 TRUE;否则,返回FALSE |
IN (option., ...) | 如果是集合 option 中的任意一个,返回 TRUE |
IS NULL | 是 NULL |
IS NOT NULL | 不是 NULL |
LIKE | 模糊匹配。%表示可以匹配任意多个(包括0个)任意字符;_表示只能匹配任意一个字符(只能是1个) |
注意:这里和 LIKE 搭配的%和 _ 都是占位符。
运算符
运算符 | 说明 |
AND | 多个条件同时都为TRUE时,结果才是TRUE;否则为FALSE |
OR | 任意一个条件为TRUE时,结果都为TRUE;否则,就是FALSE |
NOT | 条件为TRUE时,结果为FALSE;反之,则为TRUE |
注意:AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分。其实我们建议只要是在使用时,遇到了有歧义的部分都是使用()给表明优先级的。
代码练习:
-- 查询价格在60~100之间的书籍相关信息(这里也可以用 >= 和 <= 来实现)
select * from books where price between 60 and 100;-- 查询name中含有 数据结构 的书籍
select * from books where name like '%数据结构%';
-- 以下书籍皆可被查询到:大话数据结构、数据结构C语言版
修改(Update)
语法:
UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;
参数说明以及注意事项:
1、 table_name 是要更新数据的表的名称;
2、columnl,column2,..是要更新的列的名称;
3、valuel,value2,..是新的值,用于替换l日的值;
4、WHERE condition 是一个可选的子句,用于指定更新的行。如果省略WHERE子句,将更新表中的所有行,这是一个非常危险的操作;
5、WHERE子句后面也可以跟order by子句和limit 语句
代码练习:
-- 将书名为大话数据结构的书籍的相关信息更改为下面这些信息
update books set name = '阿里巴巴《Java开发手册-嵩山版》',
author = '众多Java开发者们', price = 0, sort = '计算机'
where name = '大话数据结构'; -- where子句一定不能少,否则就是全部修改了-- 将书名为大话书籍结构的书籍价格提高为原来的两倍
update books set price = price * 2 where name = '大话数据结构';-- 将书籍价格最贵的前三种,全部减去10元
update books set price = price - 10 order by price desc limit 3;
注意:SQL语法中没有复合运算符。如:+=、-=、*=.....这些操作都是错误的。
我们知道了当没有写where子句时,便会全部修改,从这里也侧面反映了一个问题:当匹配到符合要求的数据时,会一次性全部修改,而不是只修改一条数据。
删除(Delete)
语法:
-- 注意:这里删除的是一条一条的记录,即数据行
DELETE FROM table_name WHERE condition;
参数以及注意事项:
1、table_name是你要删除数据的表的名称;
2、WHERE condition 是一个可选的子句,用于指定删除的行。如果省略 WHERE 子句,将删除表中的所有行,即将表中所有数据全部删除了,这同样是一个非常危险的操作;
3、同样在WHERE子句后面可以跟 order by子句和limit 语句。
代码练习:
-- 删除书籍名为大话数据结构或者是数据结构C语言版的全部信息(这里一定要加where子句)
delete from books where name = '大话数据结构' or name = '数据结构C语言版';-- 将价格最低的三本书全部删除
delete from books order by price asc limit 3;
上面就是关于数据表的增删查改操作。
好啦!本期 初始MYSQL数据库(2)——创建、查询、更新、删除数据表的相关操作 的学习就到处结束啦!我们下一期再一起学习吧!
相关文章:

初始MYSQL数据库(2)——创建、查询、更新、删除数据表的相关操作
找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程(ಥ_ಥ)-CSDN博客 所属专栏: MYSQL 前面我们学习了创建、删除数据库以及创建、查看、删除数据表的相关操作。 我们知道数据库中所存储的数据其实就是数据表中一条一条的记…...

OpenCV直方图计算
#include <opencv2/opencv.hpp> #include <vector>using namespace cv; using namespace std;int main() {cout << "直方图calcHist" << endl;Mat src imread("left.png", IMREAD_GRAYSCALE);if (src.empty()){cout << &qu…...

多线程篇(并发相关类- 原子操作类)(持续更新迭代)
目录 前言 一、原子变量操作类(AtomicLong为例) 1. 前言 2. 实例 二、JDK 8新增的原子操作类LongAdder 三、LongAccumulator类原理探究 前言 JUC包提供了一系列的原子性操作类,这些类都是使用非阻塞算法CAS实现的,相比使用…...

数学建模常用工具总结
数学建模常用工具总结 绘图篇pythonMATLABLIVEGAP CHARTSApache EChartsBioLadderHiplot Pro 生物医学可视化平台Graph EditorRAWGraphs 2.0ExcalidrawPPT绘图 配色篇Color SpaceAdobe Color 素材篇手绘素材插画网iconfont-阿里巴巴矢量图标库下面四个都是实物风格的素材&#…...
【Redis】为什么选择 Redis 做缓存?
近期文章: 【Redis】Redis 底层的数据结构(结合源码) 【MySQL】索引底层的数据结构 BTree 在系统开发中,我们经常会使用 Redis 作为缓存系统,但你知道为什么要使用缓存吗?为什么是使用 Redis 作为缓存呢&…...
Flutter 开发常用第三方库总结
Flutter 开发常用第三方库总结 常用库 常用库 屏幕适配flutter_screenutil加载 svg flutter_svg状态管理 flutter_bloc(bloc、equatable)、provider视频播放器chewie图片缓存cached_network_image网络请求 dio设备信息查询device_info_plus文件路径 pat…...

OpenCV中的颜色映射函数applyColorMap的使用
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 OpenCV 中应用类似于 GNU Octave 或 MATLAB 中的颜色映射,虽然 OpenCV 中的颜色映射类型与 GNU Octave 或 MATLAB 中的颜色映射类型名…...

Ubuntu22.04安装colmap
首先上这里查看自己电脑GPU的CMAKE_CUDA_ARCHITECTURES 终端输入以下内容安装预先的前置依赖 sudo apt-get install \git cmake ninja-build build-essential \libboost-program-options-dev libboost-filesystem-dev \libboost-graph-dev libboost-system-dev libboost-tes…...
认识GO语言中的nil,零值与空结构体
go语言的初学者,特别是java开发者新学习go语言,对于一些和java类似但是又有差异的概念很容易混淆,比如说go中的零值,nil 和 空结构体。本文就来详细探讨一下go中这些特殊概念的含义和实际场景中的应用: 零值 零值&…...
Node.js sqlite3:Statement对象详解
在Node.js的sqlite3库中,Statement对象是一个非常重要的概念。它代表了一个预编译的SQL语句,可以多次执行以提高性能。通过使用Statement对象,你可以避免重复解析和编译SQL语句的开销,特别是在需要频繁执行相同SQL语句的情况下。本…...

ELK学习笔记——如何给Kibana新增用户和角色
Kibana新增用户和角色 首先用超管账号登录上Kibana,按照下面步骤操作 1、创建角色 按图操作 2、创建用户 按图操作 3、给用户分配角色 至此,角色和用户绑定成功; 最后,可以退出管理员账号,登录这个新…...

Minikube Install Kubernetes v1.18.1
文章目录 简介安装工具配置代理运行集群检查集群加入rancher 简介 模拟客户环境,测试 kubernetes v1.18.x 是否可以被 rancher v2.9.1 纳管。 安装工具 docker 安装Install and Set Up kubectl on Linux 安装 minikube 配置代理 docker proxylinux proxy 运行…...
重修设计模式-创建型-工厂模式
重修设计模式-创建型-工厂模式 一、概述 工厂模式(Factory Pattern)是设计模式中非常基础且常用的一种模式,主要目的是通过封装对象的创建过程,从而实现代码的解耦和灵活性的提升。 工厂模式的核心思想 封装对象的创建&#x…...

使用Cskin时候 遇到按钮有默认阴影问题解决
使用Cskin时候 遇到按钮有默认阴影 设置 DrawType 属性就可以了...

121.rk3399 uboot(2017.09) 源码分析1(2024-09-05)
参考源码 : uboot(2017.09) 硬件平台:rk3399 辅助工具:linux虚拟机,sourceinsight4,文件浏览器(可以使用samba访问),ultraeidt(查看bin文件比较方便) 说明:…...
【图论】虚树 - 模板总结
适用于解决一棵树中只需要用到少部分点的时候,将需要用到的点提出来单独建一棵树 /********************* 虚树 *********************/ struct edge {int to, next;int val; };struct Virtual_Tree {int n; // 点数int dfn[N]; // dfs序int dep[N]; // 深度int fa…...

[C#学习笔记]注释
官方文档:Documentation comments - C# language specification | Microsoft Learn 一、常用标记总结 1.1 将文本设置为代码风格的字体:<c> 1.2 源代码或程序输出:<code> 1.3 异常指示:<exception> 1.4 段落 <para> 1.5 换行&…...

c# checkbox的text文字放到右边
checkbox的text文字放到右边 实现方法如下图 特此记录 anlog 2024年9月2日...

【node.js】基础之修改文件
node.js 基础(一) node.js是什么? 上面这句话的意思就是:Node.js 是一个开源的,跨平台的javascript运行环境。通俗的说就是一个应用程序或者说是一个软件,可以运行javascript。 Node.js的作用: 开发服务器应用。 将数…...

Notepad++回车不自动补全
问题 使用Notepad时,按回车经常自动补全,但我们希望回车进行换行,而不是自动补全,而且自动补全使用Tab进行补全足够了。下文介绍设置方法。 设置方法 打开Notepad,进入设置 - 首选项 - 自动完成,在插入选…...

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)
题目:3442. 奇偶频次间的最大差值 I 思路 :哈希,时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况,哈希表这里用数组即可实现。 C版本: class Solution { public:int maxDifference(string s) {int a[26]…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...

CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...

STM32F4基本定时器使用和原理详解
STM32F4基本定时器使用和原理详解 前言如何确定定时器挂载在哪条时钟线上配置及使用方法参数配置PrescalerCounter ModeCounter Periodauto-reload preloadTrigger Event Selection 中断配置生成的代码及使用方法初始化代码基本定时器触发DCA或者ADC的代码讲解中断代码定时启动…...
Golang dig框架与GraphQL的完美结合
将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用,可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器,能够帮助开发者更好地管理复杂的依赖关系,而 GraphQL 则是一种用于 API 的查询语言,能够提…...

让AI看见世界:MCP协议与服务器的工作原理
让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...
06 Deep learning神经网络编程基础 激活函数 --吴恩达
深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...

回溯算法学习
一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...

【JVM】Java虚拟机(二)——垃圾回收
目录 一、如何判断对象可以回收 (一)引用计数法 (二)可达性分析算法 二、垃圾回收算法 (一)标记清除 (二)标记整理 (三)复制 (四ÿ…...