【MySQL】数据基本的增删改查操作

news2024/9/24 17:19:03

新增数据(Create)

在MySQL中,增加数据的操作主要使用 INSERT 语句。下面我们将分为两部分:单行数据插入和多行数据插入。

一、单行数据插入

  1. 全列插入: 当你要插入一行数据到表中并且要提供所有列的值时,可以使用如下语法:示例: 假设我们有一个名为 students 的表,它有三个列:idname 和 age

INSERT INTO students (id, name, age) VALUES (1, 'Alice', 20);

    2.指定列插入: 如果你只想插入部分列的值,没提供的列将会使用默认值或者 NULL示例: 在 students 表中仅插入 name 和 age,假设 id 列自动递增。

INSERT INTO students (name, age) VALUES ('Bob', 22);

二、多行数据插入

  1. 指定列插入: 可以在一次操作中插入多行数据,且只指定想插入的列。示例: 向 students 表中插入多名学生的 name 和 age

INSERT INTO students (name, age) VALUES ('Charlie', 19), ('David', 21), ('Eva', 20);

查询数据(Retrieve)

在MySQL中,查询数据的操作主要使用 SELECT 语句。下面将详细描述各类查询方式,包括全列查询、指定列查询、条件过滤等。

一、全列查询

当你需要从一个表中检索所有列的数据时,可以使用 * 通配符。

SELECT * FROM 表名;

二、指定列查询

如果只需要查询表中的特定列,可以在 SELECT 语句中明确列出这些列名。

SELECT 列1, 列2 FROM 表名;

三、查询字段为表达式

可以在 SELECT 语句中使用表达式,比如数学运算、字符串操作等。

SELECT 列1, 列2, (列3 * 2) AS 新列名 FROM 表名;

四、别名

可以使用 AS 关键字为查询结果的列创建一个别名,便于阅读。

SELECT 列名 AS 别名 FROM 表名;

五、去重:DISTINCT

如果想要查询结果中的重复数据去除,可以使用 DISTINCT 关键字。

SELECT DISTINCT 列名 FROM 表名;

还可以指定多个列。

SELECT DISTINCT 列名1,列名2 FROM 表名;

六、排序:ORDER BY

可以使用 ORDER BY 子句对查询结果进行排序。默认是升序 ASC,也可以指定降序 DESC

SELECT 列名 FROM 表名 ORDER BY 列名 [ASC|DESC];

还可以在排序里使用表达式

SELECT 列名 FROM 表名 ORDER BY 表达式 [ASC|DESC];

七、条件查询:WHERE

可以使用 WHERE 子句添加查询条件,筛选满足条件的记录。

SELECT 列名 FROM 表名 WHERE 条件;

在MySQL中,WHERE 子句用于过滤查询结果,可以使用多种运算符来构建查询条件。以下是常用的运算符分类及示例:

1. 比较运算符

  • 等于 (=)
  • 可以判断空值的等于(<=>)
  • 不等于 (<> 或 !=)
  • 大于 (>)
  • 小于 (<)
  • 大于等于 (>=)
  • 小于等于 (<=)

2. 逻辑运算符

  • 与 (AND)
  • 或 (OR)
  • 非 (NOT)

3. 范围运算符

  • 在范围内 (BETWEEN ... AND ...)
  • 在集合中 (IN)
  • 模糊匹配 (LIKE)

4. 空值检查

  • 为空 (IS NULL)
  • 非空 (IS NOT NULL)

这些运算符可以组合使用,以构建复杂的查询条件。

 注:
1. WHERE条件可以使用表达式,但不能使用别名。
2. AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分。

八、分页查询:LIMIT

在查询结果中进行分页,可以使用 LIMIT 关键字,指定返回的记录数和起始位置。

SELECT 列名 FROM 表名 LIMIT 返回条数 , offset 起始位置;

查询代码案例:

查找总成绩前五名的学生的姓名和总成绩

首先创建一个表,插入多条数据

查询代码

select name , math + chinese as total from student order by total limit 5;

查询结果

修改(Update)

在MySQL中,修改数据的操作主要使用 UPDATE 语句。通过 UPDATE 语句,可以更新数据库表中已存在的数据。下面将详细描述其用法。

语法结构

基本的 UPDATE 语法如下:

UPDATE 表名 SET 列1 = 值1, 列2 = 值2, ... WHERE 条件;

组成部分

  1. 表名:要更新数据的表的名称。
  2. SET:用来指定要更新的列以及对应的新值。
  3. :要更新的列名,可以是一个或多个列。
  4. :每个列对应的新值。
  5. WHERE:用来指定条件,确保只更新符合条件的记录。如果不加 WHERE,将会更新表中的所有记录。

操作步骤

  1. 基本更新:如果需要更新单个列的值,可以直接在 SET 子句中指定。

    • 示例:将 students 表中 ID 为 1 的学生的 name 更新为 Alice
UPDATE students SET name = 'Alice' WHERE id = 1;

多列更新:可以在 SET 子句中同时更新多个列的值。

  • 示例:将 ID 为 2 的学生的 name 更新为 Bob,同时将 age 更新为 22。
UPDATE students SET name = 'Bob', age = 22 WHERE id = 2;

条件更新:使用 WHERE 子句来限制更新的记录。

  • 示例:将所有年龄大于 20 的学生的 age 更新为 21。
UPDATE students SET age = 21 WHERE age > 20;

全表更新:如果省略 WHERE 子句,所有记录将会被更新。

  • 示例:将 students 表中所有学生的 age 更新为 18(注意使用前需仔细考虑)。
UPDATE students SET age = 18;

注意事项

  • 小心使用 WHERE 子句:在执行更新操作时,必须确保条件的准确性,以避免意外更新全表的数据。
  • 验证更新结果:在大型数据修改操作后,最好执行查询语句确认数据更新的结果是否符合预期。

结论

通过以上的介绍,可以通过 UPDATE 语句有效地修改MySQL数据库表中的数据,并根据需要灵活地指定更新的条件及列。

删除(Delete)

在MySQL中,删除数据的操作主要使用 DELETE 语句。通过 DELETE 语句,可以从数据库表中删除已存在的记录。下面将详细描述其用法。

语法结构

基本的 DELETE 语法如下:

DELETE FROM 表名 WHERE 条件;

组成部分

  1. 表名:要删除数据的表的名称。
  2. WHERE:用来指定条件,确保只删除符合条件的记录。如果不加 WHERE,则会删除表中的所有记录。

操作步骤

  1. 基本删除:如果需要删除符合特定条件的单条或多条记录,可以使用 WHERE 子句。

    • 示例:从 students 表中删除 ID 为 1 的学生记录。
DELETE FROM students WHERE id = 1;

条件删除:可以使用更复杂的条件来删除记录。

  • 示例:删除所有年龄小于 18 的学生记录。
DELETE FROM students WHERE age < 18;

全表删除:如果省略 WHERE 子句,所有记录将会被删除。

  • 示例:从 students 表中删除所有学生记录(注意使用前需仔细考虑)。
DELETE FROM students;

注意事项

  • 小心使用 WHERE 子句:在执行删除操作时,确保条件的准确性,以避免意外删除全表的数据。
  • 备份重要数据:在进行大规模删除操作之前,最好先备份数据,以免意外损失。
  • 验证删除结果:删除操作后,可以执行查询语句确认数据删除的结果是否符合预期。

结论

通过以上的介绍,可以使用 DELETE 语句有效地删除MySQL数据库表中的数据。使用时应谨慎,确保对删除将产生的后果有清晰的认识。

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

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

相关文章

工业互联网产教融合实训基地解决方案

一、引言 随着“中国制造2025”战略的深入实施与全球工业4.0浪潮的兴起&#xff0c;工业互联网作为新一代信息技术与制造业深度融合的产物&#xff0c;正引领着制造业向智能化、网络化、服务化转型。为培养适应未来工业发展需求的高素质技术技能人才&#xff0c;构建工业互联网…

较新版本Cesium使用本地源码编译打包

0 写作背景 较新版本的Cesium&#xff08;1.100版本及以后&#xff09;在代码结构上做了一定的调整&#xff0c;打包方式也随之发生了一些变化。 Starting with version 1.100, CesiumJS will be published alongside two smaller packages cesium/engine and cesium/widgets …

JAVA中的volatile和synchronized关键字详解

1.volatile 保证可见性&#xff1a;当一个变量被声明为volatile&#xff0c;编译器和运行时都会注意到这个变量是共享的&#xff0c;并且每次使用这个变量时都必须从主内存中读取&#xff0c;而不是从线程的本地缓存或者寄存器中读取。这确保了所有线程看到的变量值都是最新的…

【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;数据结构 目录 前言 一、树 1.树的概念与结构 2.树的相关术语 3.树的表示方法 4.树型结构的实际应用场景 二、二叉树 1.二叉树的概念与结构 2.二叉树的…

RabbitMQ再回首--往事如梦

这文章你就读吧&#xff0c;越读越&#x1f978;&#xff0c;一读一个不吱声 可靠的&#x1f430;警官&#xff1a;rabbitMQ&#xff0c;功能全面&#xff0c;不丢数据&#xff0c;体量小&#xff0c;容易堆积 声明exchange channel . exchangeDeclare ( String exchange , …

在EA框架下增强开展AI项目研发

1.在战略规划阶段实施AI模型选择的工作 有许多可用的 AI 模型&#xff0c;企业架构师必须从监督学习模型、无监督学习模型、强化学习模型和深度学习模型中选择正确的模型。这些模型支持跨不同领域的各种应用。**企业架构师应根据 AI 项目的具体要求选择合适的 AI 模型和架构。*…

WeiXin Video

WeiXin Video 微信视频号电脑版本流程 菜单 - 视频号直播工具 &#xff08;没有下载&#xff0c;需要下载&#xff0c;这里不写了&#xff09; 找到菜单里面的【视频号】 进入一个新的页面&#xff08;第①个页签&#xff09;&#xff0c;点击【头像】 进入一个新的页面&#…

编程深水区之并发⑥:C#的线程池

绝大多数情况下&#xff0c;我们都应该使用CLR线程池&#xff0c;而不是直接操作Thread&#xff0c;本章节介绍直接操作线程池的ThreadPool&#xff0c;但实际开发中也很少直接使用它。 一、CLR和线程池 1.1 CLR的主要工作 CLR&#xff08;Common Language Runtime&#xff0…

在Docker上部署Ollama+AnythingLLM完成本地LLM Agent部署

在当今快速发展的人工智能领域&#xff0c;本地部署大型语言模型&#xff08;LLM&#xff09;Agent正逐渐成为企业和研究者关注的焦点。本地部署不仅能够提供更高的数据安全性和隐私保护&#xff0c;还能减少对外部服务的依赖&#xff0c;提高响应速度和系统稳定性。本文将介绍…

04 Haproxy搭建Web集群

4.1 案例分析 4.1.1 案例概述 Haproxy是目前比较流行的一种群集调度工具&#xff0c;同类群集调度工具有很多&#xff0c;如LVS和Nginx。相比较而言&#xff0c;LVS 性能最好&#xff0c;但是搭建相对复杂;Nginx 的upstream模块支持群集功能&#xff0c;但是对群集节点健康检…

PHP反序列化POP链构造:理解与利用

如有疑惑&#xff0c;尽管提问&#xff1b;如有错误&#xff0c;请您指正&#xff01; 以[MRCTF2020]Ezpop为例&#xff1a; 本题的入口&#xff1f;通过pop传入序列化数据 本题的出口&#xff1f;通过include包含flag.php 我们要传入什么&#xff1f;序列化数据&#xff0c…

Can‘t use openai in command prompt

题意&#xff1a;在命令提示符&#xff08;Command Prompt&#xff09;中不能使用OpenAI 问题背景&#xff1a; I know this is a super basic question but pls help me with this problem I have properly installed the openai with the nodejs library using npm install …

React 用户点击某个元素后只执行一次操作

React开发中经常会遇到需求&#xff1a;用户点击某个元素后只执行一次特定操作。比如&#xff0c;用户点击按钮后弹出提示框&#xff0c;但希望再次点击按钮不再触发提示框。针对这种需求&#xff0c;可以封装一个自定义Hooks来实现只允许点击一次的功能。 import {useCallbac…

找不到符号 javax.servlet.WriteListener

1、问题 找不到符号2、原因 JDK1.8升级到高版本后&#xff0c;需要手动引入包。 在打包时&#xff0c;需要注意一下是否是在父类打包&#xff0c;而不是在某个model打包。 3、解决 引入 <dependency><groupId>javax.servlet</groupId><artifactId>…

性能测试学习笔记

一、性能测试是什么&#xff1f; 1.生活案例&#xff1a; 学校选课系统&#xff0c;就会经常崩溃&#xff01;&#xff01;&#xff01;&#xff01; 2.性能测试的定义 测试人员借助测试工具&#xff0c;模拟系统在不同场景下&#xff0c;对应的性能指标是否达到预期 3.性能…

Day34 | 322. 零钱兑换 279.完全平方数 139.单词拆分

语言 Java 322. 零钱兑换 零钱兑换 题目 给你一个整数数组 coins &#xff0c;表示不同面额的硬币&#xff1b;以及一个整数 amount &#xff0c;表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额&#xff0c;返…

亚信安慧AntDB-T:使用Brin索引提升OLAP查询性能以及节省磁盘空间

前 言 在这个信息量爆炸的时代&#xff0c;数据库面临着海量数据的挑战&#xff0c;如何提升OLAP业务的查询性能、如何节省磁盘空间等问题已经成为了数据库的痛点之所在。本篇着重介绍亚信安慧AntDB-T中Brin索引的实现过程以及应用在OLAP业务中带来的性能提升和存储降低。 亚…

【倍智信息-倍智信息系统0day漏洞】

目录 一、漏洞说明 二、资产测绘 三、漏洞复现 四、批量验证 一、漏洞说明 倍智信息系统使用了组件Spring Actuator 作为 wei Spring acloud提供的一个功能模块&#xff0c;用于管理和监控 Spring 应用程序。如果未正确配置安全性&#xff0c;特别是在生产环境中&…

TinyWebserver的复现与改进(1):服务器环境的搭建与测试

计划开一个新坑, 主要是复现qinguoyi/TinyWebServer项目&#xff0c;并且使用其它模块提升性能。 本文开发服务器配置&#xff1a;腾讯云轻量级服务器&#xff0c;CPU - 2核 内存 - 2GB&#xff0c;操作系统 Ubuntu Server 18.04.1 LTS 64bit 打开端口 需要打开服务器3306、80…

字节跳动2025校园招聘内推

快来投递简历吧&#xff1a;https://job.toutiao.com/s/ir2RpsLR 快来投递简历吧&#xff1a;https://job.toutiao.com/s/ir2RpsLR