MySQL中表的增删改查(CRUD)
一.在表中增加数据(Create)
INSERT [INTO] TB_NAME [(COLUMN1,COLUMN2,...)] VALUES (value_list1),(value_list2),...;
- into可以省略
- 可仅选择部分列选择插入,column即选择的列, 如图例可以选择仅在valuelist中插入age和id如果不指定列则默认为全列插入=
- 一次可以插入多行,用逗号隔开,如图例中values后两个括号即插入两行数据
- 插入的数据必须与指定列数一一对应
二.数据库中查询数据(Retrieve)
SELECT 列1, 列2, ...
FROM tb_name
[WHERE 条件]
[ORDER BY 排序列]
[LIMIT 数量];
-
可以用select * 查询所有数据但数据过多时可能造成性能问题
-
查询特定列时select 列1,列2即可如图仅查询了id与age
-
可以结合where,语法为where +条件 进行条件筛选(where类比编程语言中的if语句)
-
可以用order by排序,具体语法为 order by+列名(即以此列数据排序)+(desc或asc也可以省略,省略默认为asc)
其中desc为降序(从大到小)asc为升序(从小到大) -
可以结合limit进行分页查询,并可以运用offset,注意:“必须”配合 ORDER BY:未指定排序时,查询结果的顺序可能不稳定,影响分页准确性。
不配合不报错,但是同一查询在不同时间执行,可能因数据变化或优化器调整返回不同顺序的结果
-- 记录的起始下标为0,limit n为筛选从0下标开始的n条数据
SELECT * FROM users LIMIT n;
-- 筛选从s下标开始的n条数据
SELECT * FROM users LIMIT s,n;
-- 结合offset分页:筛选从s下标开始的n条数据,该写法比第二种写法明确更加推荐使用该写法
SELECT * FROM users LIMIT n OFFSET s;
- 去重操作distinct,消除重复行,返回唯一不同的值,适用于需要排除重复数据的场景,并且可以针对一列或多列组合去重,注意DISTINCT 将 NULL 视为一个唯一值
-- 单列去重
SELECT DISTINCT 列名 FROM 表名;-- 多列去重(组合唯一)
SELECT DISTINCT 列1, 列2 FROM 表名;
- 可以查询有关列的表达式,并且表达式可以用as关键字写为别名
三.表中已有数据的修改(Update)
UPDATE table_name
SET column1 = value1, column2 = value2, ...
[WHERE condition]
[ORDER BY ...] -- 某些数据库支持(如 MySQL)
[LIMIT ...]; -- 某些数据库支持(如 MySQL)
可以第一对多列进行操作,并可配合一系列条件筛选否则为更改每一行
-- 同时修改用户的姓名和年龄
UPDATE users SET name = '张三',age = 28 WHERE user_id = 100;
四.表的删除
DELETE FROM table_name
[WHERE condition]
[ORDER BY ...] -- 某些数据库支持(如 MySQL)
[LIMIT ...]; -- 某些数据库支持(如 MySQL)
注意:可删除部分或全部数据(通过条件来筛选)
-- 删除所有年龄大于 100 的用户
DELETE FROM users WHERE age > 100;-- 删除前 10 条订单记录(MySQL 支持 LIMIT)
DELETE FROM orders ORDER BY order_date LIMIT 10;
五.条件查询的补充
注意:
- = 对null不安全,null=null的结果是null
特别地<=>也是等于,并且对null安全,NULL <=> NULL 结果可得 1 (TRUE) - 对于逻辑运算符的优先级记忆要求不高,可以依靠添加括号达成想法
- 模糊查询用到关键字like
模糊查询中
张% 即为张开头的所有数据,%匹配任意长度字符
_ 则仅匹配一个字符 张 _ 仅能表示张开头,长度为2的字符
ESCAPE,当你要搜索的内容本身包含 % 或 _ 时,必须用它来“取消”通配符的特殊含义
-- 错误写法:会匹配到 100abc、100xyz 等
SELECT * FROM products
WHERE title LIKE '100%';-- 正确写法:精确匹配 100%
SELECT * FROM products
WHERE title LIKE '100!%%' ESCAPE '!';
- BETWEEN … AND …和IN (…)注意
BETWEEN … AND …的左右都是闭区间
并且对非数字类型的支持
不仅限于数字,还可用于日期、字符串范围筛选,语法简洁性优势更明显
-- 查询价格在 100~500 之间的商品
SELECT * FROM products WHERE price BETWEEN 100 AND 500;
-- 等效于
WHERE price >= 100 AND price <= 500;-- 查询北京、上海、广州的用户
SELECT * FROM users WHERE city IN ('北京', '上海', '广州');-- 等效于
WHERE city = '北京' OR city = '上海' OR city = '广州';
相关文章:

MySQL中表的增删改查(CRUD)
一.在表中增加数据(Create) INSERT [INTO] TB_NAME [(COLUMN1,COLUMN2,...)] VALUES (value_list1),(value_list2),...;into可以省略可仅选择部分列选择插入,column即选择的列, 如图例可以选择仅在valuelist中插入age和id如果不指…...

项目思维vs产品思维
大家好,我是大明同学。 这期内容,我们来聊一下项目思维和产品思维的区别。 项目是实施关键,力求每一步都精准到位;产品则是战略导向,确保所选之路正确无误。若缺乏优异成果,即便按时完成,也只…...

游戏引擎学习第285天:“Traversables 的事务性占用”
回顾并为当天的工作做准备 我们有一个关于玩家移动的概念,玩家可以在点之间移动,而且当这些点移动时,玩家会随之移动。现在这个部分基本上已经在工作了。我们本来想实现的一个功能是:当玩家移动到某个点时,这个点能“…...
基于DWT的音频水印算法
基于离散小波变换(DWT)的音频水印算法是一种结合信号处理与信息隐藏的技术,旨在将版权信息或标识隐蔽地嵌入音频信号中,同时保证不可感知性和鲁棒性。以下是该算法的核心步骤及关键技术点: 1. 算法基本原理 DWT…...
小刚说C语言刷题—1700请输出所有的2位数中,含有数字2的整数
1.题目描述 请输出所有的 2 位数中,含有数字 2 的整数有哪些,每行 1个,按照由小到大输出。 比如: 12、20、21、22、23… 都是含有数字 2的整数。 输入 无 输出 按题意要求由小到大输出符合条件的整数,每行 1 个。…...

文件上传Ⅲ
#文件-解析方案-执行权限&解码还原 1、执行权限 文件上传后存储目录不给执行权限(即它并不限制你上传文件的类型,但不会让相应存有后门代码的PHP文件执行,但是PNG图片是可以访问的) 2、解码还原 数据做存储,解…...
Ubuntu中配置【Rust 镜像源】
本篇主要记录Ubuntu中配置Rust编程环境时,所需要做的镜像源相关的配置 无法下载 Rust 工具链 通过环境变量指定 Rust 的国内镜像源(如中科大或清华源)。 方法一:临时设置镜像 export RUSTUP_DIST_SERVERhttps://mirrors.ustc.e…...
Room数据库
Room数据库 Room是Android Jetpack组件中的一款SQLite数据库抽象层框架,旨在简化本地数据库操作,提供编译时SQL校验、类型与安全、与LiveData/Flow无缝集成等特性。 1. 什么是Room 定义: Room 是 Android Jetpack 提供的一个 ORMÿ…...

基于深度学习的工业OCR数字识别系统架构解析
一、项目场景 春晖数字识别视觉检测系统专注于工业自动化生产监控、设备运行数据记录等关键领域。系统通过高精度OCR算法,能够实时识别设备上显示的关键数据(如温度、压力、计数等),并定时存储至Excel文件中。这些数据对于生产过…...

go-中间件的使用
中间件介绍 Gin框架允许开发者在处理请求的过程中加入用户自己的钩子(Hook)函数这个钩子函数就是中间件,中间件适合处理一些公共的业务逻辑比如登录认证,权限校验,数据分页,记录日志,耗时统计 1.定义全局中间件 pac…...
谷歌曾经的开放重定向漏洞(如今已经修复) -- noogle DefCamp 2024
题目描述: 上周,我决定创建自己的搜索引擎。这有点难,所以我背上了另一个。我也在8000端口上尝试了一些东西。 未发现题目任何交互,但是存在一个加密js const _0x43a57f _0x22f9; (function(_0x3d7d57, _0x426e05) {const _0x16c3fa _0x22f9, _0x3187…...
(7)python开发经验
文章目录 1 找不到资源文件2 使用subprocess执行时有黑色弹窗3 找不到exec4 pyside6-project lupdate的bug5 找不到pyd模块6 pyd模块编码错误7 运行显示Qt platform plugin "windows" in "8 tr()包含的字符串无法被翻译 更多精彩内容👉内容导航 &…...

学习以任务为中心的潜动作,随地采取行动
25年5月来自香港大学、OpenDriveLab 和智元机器人的论文“Learning to Act Anywhere with Task-centric Latent Actions”。 通用机器人应该在各种环境中高效运行。然而,大多数现有方法严重依赖于扩展动作标注数据来增强其能力。因此,它们通常局限于单一…...

15.springboot-控制器处理参数传递
22.springMVC Spring MVC 是非常著名的 Web 应用框架,现在的大多数 Web 项目都采用 Spring MVC。它与 Spring 有着紧 密的关系。是 Spring 框架中的模块,专注 Web 应用,能够使用 Spring 提供的强大功能,IoC , Aop 等等。 Spring…...

半成品的开源双系统VLA模型,OpenHelix-发表于2025.5.6
半成品的开源双系统VLA模型,OpenHelix https://openhelix-robot.github.io/ 0. 摘要 随着OpenVLA的开源,VLA如何部署到真实的机器人上获得了越来越多的关注,各界人士也都开始尝试解决OpenVLA的效率问题,双系统方案是其中一个非…...

网站推荐(第四期)
好久没有推荐过网站了,重拾推荐一波,最近发现这几个确实不错。 某火箭共享账号 官网:https://id.bocchi.vip/ 苹果用户专用,都是买了某火箭的账号,懂得都懂。 这玩意竟然还是个开源项目,项目地址&#x…...

2024 睿抗机器人开发者大赛CAIP-编程技能赛-专科组(国赛)解题报告 | 珂学家
前言 题解 2024 睿抗机器人开发者大赛CAIP-编程技能赛-专科组(国赛),陈越姐姐出题。 国赛比省赛,难度增强了不少,题目就剩下4个题了。 涉及堆栈,hash表,优先队列等高阶数据结构的使用&#x…...

git工具使用详细教程-------命令行和TortoiseGit图形化
下载 git下载地址:https://git-scm.com/downloads TortoiseGit(图形化工具)下载地址:https://tortoisegit.org/download/ 认识git结构 工作区:存放代码的地方 暂存区:临时存储,将工作区的代码…...

Mysql新增
插入一个记录需要的时间由下列因素组成,其中的数字表示大约比例: 连接:(3)发送查询给服务器:(2)分析查询:(2)插入记录:(1x记录大小)插入索引:(1x索引&#x…...

AI Agent开发第64课-DIFY和企业现有系统结合实现高可配置的智能零售AI Agent(上)
开篇 我们之前花了将近10个篇章讲Dify的一些基础应用,包括在讲Dify之前我们讲到了几十个AI Agent的开发例子,我不知道大家发觉了没有,在AI Agent开发过程中我们经常会伴随着这样的一些问题: 需要经常改猫娘;需要经常改调用LLM的参数,甚至在一个流程中有3个节点,每个节点…...

【嵌入式】记一次解决VScode+PlatformIO安装卡死的经历
PlatformIO 是开源的物联网开发生态系统。提供跨平台的代码构建器、集成开发环境(IDE),兼容 Arduino,ESP8266和mbed等。 开源库地址:https://github.com/platformio 在 VScode 中配置 PlatformIO 插件,记录…...
文件系统交互实现
关于之前的搭建看QT控件文件系统的实现-CSDN博客,接下来是对本程序的功能完善,我想着是这样设计的,打开一个目录以后,鼠标选中一个项可以是目录,也可以是文件,右键可以出现一个菜单选择操作,比如…...

MySQL 事务(一)
文章目录 CURD不加控制,会有什么问题CURD满足什么属性,能解决上述问题?什么是事务为什么要有事务事务的版本支持了解事务的提交方式 事务常见操作方式研究并发场景事务的正常操作事务的非正常情况的案例结论事务操作的注意事项 CURD不加控制&…...

【全解析】EN 18031标准下的 AUM 身份认证机制[下篇]
在上篇文章中,我们详细介绍了EN 18031标准中AUM身份认证机制的AUM - 1、AUM - 2和AUM - 3条款。今天,我们将继续深入探讨AUM - 4到AUM - 6的相关内容,进一步了解该标准如何保障无线电设备的身份认证安全。 一、AUM - 4:更改认证器…...
常见排序算法及复杂度分析
冒泡排序 (Bubble Sort) 基本思想 相邻元素比较,大的元素后移 每轮将最大元素"冒泡"到末尾 代码实现 void bubbleSort(int arr[], int n) {for (int i 0; i < n-1; i) {for (int j 0; j < n-i-1; j) {if (arr[j] > arr[j1]) {swap(arr[j]…...

彻底解决sublime text4无法打开install package界面安装插件问题
1. 说明 最新版的 sublime text4,不管是通过软件自带的命令安装的 package control 插件,还是从官网下载的 package control 插件,之后通过 CommandShiftP 打开面板,输入 Package Control,可能找不到 Package Control…...

用户现场不支持路由映射,如何快速将安防监控EasyCVR视频汇聚平台映射到公网?
一、方案背景 随着数字化安防与智能交通管理发展,视频监控远程管理需求激增。EasyCVR作为专业视频融合平台,具备多协议接入等核心功能,是智能监控的重要工具。但实际部署中,当EasyCVR处于内网且路由器无法进行端口映射时&#…...

C#实现访问远程硬盘(附源码)
在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件。那么,这样的远程硬盘功能要怎么实现了? 这次我们将给出…...
嵌入式软件学习记录 - DAY2
一、volatile 修饰符 1. 能修饰什么? 变量(包括普通变量、指针、结构体成员等)。不能修饰函数(但函数参数或返回值可以是 volatile 类型)。 2. 作用 告诉编译器不要优化该变量的访问:每次读取或写入该变…...

图片、音频、视频都能转?简鹿格式工厂了解一下
我们每天都会接触到各种各样的音视频和图片文件。无论是拍摄的照片、录制的视频,还是下载的音频资源,它们往往以不同的格式存在——有些适合分享,有些适合编辑,而有些则仅限特定设备或平台使用。格式不统一的问题,正在…...