表的增删改查

在这里插入图片描述

文章目录

  • 1. Create(创建)
    • 1.1 insert
    • 1.2 插入否则更新
    • 1.3 替换
  • 2. Retrieve(查询)
    • 2.1 SELECT 列
    • 2.2 WHERE 条件
    • 2.3 结果排序
    • 2.4 筛选分页结果
  • 3. Update(更新)
  • 4. Delete(删除)
    • 4.1 删除数据
    • 4.2 截断表
  • 5. 插入查询结果

1. Create(创建)

1.1 insert

在这里插入图片描述
下面我们用这个表来操作:
在这里插入图片描述
单行数据 + 全列插入:
在这里插入图片描述
注意:这里在插入的时候,也可以不用指定id(当然,那时候就需要明确插入数据到那些列了),那么mysql会使用默认的值进行自增。

多行数据 + 指定列插入:
在这里插入图片描述
这里就没有指定qq的插入。

1.2 插入否则更新

由于 主键 或者 唯一键 对应的值已经存在而导致插入失败,可以选择性的进行同步更新操作语法:
在这里插入图片描述
ON DUPLICATE KEY 当发生重复key的时候。

举个例子:
在这里插入图片描述
在这里插入图片描述
我们可以看到主键为2的字段,被更新成了张三。
在这里插入图片描述
在这里插入图片描述

1.3 替换

主键 或者 唯一键 没有冲突,则直接插入。主键 或者 唯一键 如果冲突,则删除后再插入
在这里插入图片描述
在这里插入图片描述
可以看到,我们把张三删除了,然后换成了王五。

在这里插入图片描述

2. Retrieve(查询)

在这里插入图片描述
在这里插入图片描述
在这里创建了一个学生成绩表。并在里面插入了一些测试数据。
在这里插入图片描述

2.1 SELECT 列

全列查询:
上面的方式就是全列查询,通常情况下不建议使用 * 进行全列查询,1. 查询的列越多,意味着需要传输的数据量越大。 2. 可能会影响到索引的使用。

指定列查询:
指定列的顺序不需要按定义表的顺序来
在这里插入图片描述
这里的意思是只查询名字和数学的列。

查询字段为表达式:
表达式包含一个字段:
在这里插入图片描述
每个人的数学成绩都加上了10。

表达式包含多个字段:
在这里插入图片描述
为查询结果指定别名:
在这里插入图片描述
在这里插入图片描述
结果去重:
在这里插入图片描述
98 分重复了,我们可以在查询的时候进行去重。
在这里插入图片描述
加上一个distinct就可以了。

2.2 WHERE 条件

比较运算符:
在这里插入图片描述
如果我们想要查询数学成绩在80分以上的同学:
在这里插入图片描述
如果我们想要查询数学成绩在70到85之间的同学:
在这里插入图片描述
查询在集合里的数据:
在这里插入图片描述
我们也可以查询英语不及格的同学的语文成绩如何:
在这里插入图片描述
姓孙的同学 及 孙某同学:
% 匹配任意多个(包括 0 个)任意字符
在这里插入图片描述
如果我们查询除了姓孙的:
在这里插入图片描述
_ 匹配严格的一个任意字符,__匹配严格的二个任意字符
在这里插入图片描述
语文成绩好于英语成绩的同学:
在这里插入图片描述
条件中比较运算符两侧都是字段。

总分在 200 分以下的同学:
在这里插入图片描述

那么我们该如何去筛选一个NULL的字段和空字符串呢
筛选空字符串,我们可以使用=符号,但是筛选NULL,不能使用=号,可以采用<=>和IS来筛选。

逻辑运算符:
在这里插入图片描述
语文成绩 > 80 并且不姓孙的同学:
在这里插入图片描述

2.3 结果排序

在这里插入图片描述
注意:没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序

按数学成绩升序和降序显示:
在这里插入图片描述
查询同学各门成绩,依次按 数学降序,英语升序,语文升序的方式显示:
在这里插入图片描述
多字段排序,排序优先级随书写顺序。

查询同学及总分,由高到低,ORDER BY 子句中可以使用列别名:
在这里插入图片描述

2.4 筛选分页结果

语法:起始下标为 0
从 0 开始,筛选 n 条结果。SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT n;

假设我们要筛选总分前3名的:
在这里插入图片描述
从 s 开始,筛选 n 条结果。SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT s, n;

从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用。SELECT … FROM table_name [WHERE …] [ORDER BY …] LIMIT n OFFSET s;
在这里插入图片描述
建议:对未知表进行查询时,最好加一条 LIMIT 1,避免因为表中数据过大,查询全表数据导致数据库卡死

3. Update(更新)

语法:

UPDATE table_name SET column = expr [, column = expr ...]
[WHERE ...] [ORDER BY ...] [LIMIT ...]

将曹孟德同学的数学成绩变更为 60 分,语文成绩变更为 70 分:

查看原数据:
在这里插入图片描述
在这里插入图片描述
我们一定要加上where条件筛选,不然所有的成绩都会被修改。

将总成绩倒数前三的 3 位同学的数学成绩加上 30 分:
在这里插入图片描述
数据更新,不支持 math += 30 这种语法
在这里插入图片描述
更新后数据,不可以按总分升序排序取前 3 个了。
在这里插入图片描述

4. Delete(删除)

4.1 删除数据

在这里插入图片描述
在这里插入图片描述
删除整张表数据:
在这里插入图片描述
我们在这准备测试表来删除数据。
在这里插入图片描述
插入数据之后,我们就可以删除这个表了。
在这里插入图片描述
删除表之后,我们再插入一条数据,可以看到它的id还是会自增的。
在这里插入图片描述
查看表结构,AUTO_INCREMENT项一直记录。

4.2 截断表

在这里插入图片描述
然后我们还按照上面的操作:
在这里插入图片描述
然后我们截断表:
在这里插入图片描述
截断整表数据,注意影响行数是 0,所以实际上没有对数据真正操作。
在这里插入图片描述
在这里插入图片描述

5. 插入查询结果

在这里插入图片描述
删除表中的的重复记录,重复的数据只能有一份
在这里插入图片描述
思路:创建一张空表 no_duplicate_table,结构和 duplicate_table 一样
在这里插入图片描述
只能拷贝表的结构,不能把数据也拷贝过来。

将 duplicate_table 的去重数据插入到 no_duplicate_table
在这里插入图片描述
DISTINCT这个是查询时可以去重。
通过重命名表,实现原子的去重操作
在这里插入图片描述

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

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

相关文章

【算法分析与设计】动态规划(上)

目录 一、学习要点二、算法总体思想三、动态规划基本步骤四、矩阵连乘问题4.1 完全加括号的矩阵连乘积4.2 穷举法4.3 动态规划4.3.1 分析最优解的结构4.3.2 建立递归关系4.3.3 计算最优值4.3.4 用动态规划法求最优解 五、动态规划算法的基本要素5.1 最优子结构5.2 重叠子问题5.…

采集SEO方法-优化内链与外链建设

采集大量的文章数据&#xff0c;要想批量做SEO优化添加内链外链方法&#xff0c;可以使用简数采集器的处理规则实现。 简数采集器的一个处理规则&#xff0c;可以包含多种SEO方法&#xff0c;还可自由组合&#xff0c;强大灵活方便。 优化内链外链的SEO技巧&#xff1a; 1&a…

新手教程,蛋糕小程序的搭建流程一网打尽

作为一名新手&#xff0c;想要搭建一个蛋糕小程序可能会觉得有些困惑。但是&#xff0c;不用担心&#xff01;今天我将为大家详细介绍蛋糕小程序的搭建流程&#xff0c;并带大家一步步完成。 首先&#xff0c;我们需要登录乔拓云网的后台。在登录成功后&#xff0c;点击进入商城…

python使用mitmproxy和mitmdump抓包在手机上抓包(三)

现在手机的使用率远超过电脑&#xff0c;所以这篇记录用mitmproxy抓手机包&#xff0c;实现手机流量监控。 环境&#xff1a;win10 64位&#xff0c;Python 3.10.4&#xff0c;雷电模拟器4.0.78&#xff0c;android版本7.1.2&#xff08;设置-拉至最底部-关于平板电脑&#xf…

多线程总结(线程池 线程安全 常见锁)

本篇文章主要是对线程池进行详解。同时引出了单例模式的线程池&#xff0c;也对线程安全问题进行了解释。其中包含了智能指针、STL容器、饿汉模式的线程安全。也对常见的锁&#xff1a;悲观锁&#xff08;Pessimistic Locking&#xff09;、乐观锁&#xff08;Optimistic Locki…

DevOps持续集成与交付

概述 Jenkins是一个支持容器化部署的、使用Java运行环境的开源软件&#xff0c;使用Jenkins平台可以定制化不同的流程与任务、以自动化的机制支持DevOps领域中的CI与CD&#xff0c;在软件开发与运维的流程中自动化地执行软件工程项目的编译、构建、打包、测试、发布以及部署&a…

使用Vue-cli构建spa项目及结构解析

一&#xff0c;Vue-cli是什么&#xff1f; 是一个官方发布的Vue脚手架工具&#xff0c;用于快速搭建Vue项目结构&#xff0c;提供了现代前端开发所需要的一些基础功能&#xff0c;例如&#xff1a;Webpack打包、ESLint语法检查、单元测试、自动化部署等等。同时&#xff0c;Vu…

qml保姆级教程一:布局组件

&#x1f482; 个人主页:pp不会算法v &#x1f91f; 版权: 本文由【pp不会算法v】原创、在CSDN首发、需要转载请联系博主 &#x1f4ac; 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦 QML系列教程 QML教程一&#xff1a;布局组件 文章目录 锚布局anchors属…

JVM——11.JVM小结

这篇文章我们来小结一下JVM JVM&#xff0c;即java虚拟机&#xff0c;是java代码运行时的环境。我们从底层往上层来说&#xff0c;分别是硬件部分&#xff0c;操作系统&#xff0c;JVM&#xff0c;jre&#xff0c;JDK&#xff0c;java代码。JVM是直接与操作系统打交道的。JVM也…

基于复旦微的FMQL45T900全国产化ARM开发开发套件(核心板+底板)

TES745D是我司自主研制的一款基于上海复旦微电子FMQL45T900的全国产化ARM核心板&#xff08;模块&#xff09;。该核心板将复旦微的FMQL45T900&#xff08;与XILINX的XC7Z045-2FFG900I兼容&#xff09;的最小系统集成在了一个87*117mm的核心板上&#xff0c;可以作为一个核心模…

进入IT行业:选择前端开发还是后端开发?

一、前言 开发做前端好还是后端好&#xff1f;这是一个常见的问题&#xff0c;特别是对于初学者来说。在编程世界中&#xff0c;前端开发和后端开发分别代表着用户界面和数据逻辑&#xff0c;就像城市的两个不同街区一样。但是&#xff0c;究竟哪个街区更适合我们作为开发者呢…

yolox相关

yolox YOLOXYOLOX-DarkNet53yolov3作为baseline输入端Strong data augmentationMosaic数据增强MixUp数据增强注意 BackboneNeckPrediction层Decoupled headDecoupled Head 细节 Anchor-freeAnchor Based方式Anchor Free方式标签分配初步筛选精细化筛选 SimOTASimOTA Other Back…

「UG/NX」Block UI 从列表选择部件SelectPartFromList

✨博客主页何曾参静谧的博客📌文章专栏「UG/NX」BlockUI集合📚全部专栏「UG/NX」NX二次开发「UG/NX」BlockUI集合「VS」Visual Studio「QT」QT5程序设计「C/C+&#

DDS信号发生器波形发生器VHDL

名称&#xff1a;DDS信号发生器波形发生器 软件&#xff1a;Quartus 语言&#xff1a;VHDL 要求&#xff1a; 在EDA平台中使用VHDL语言为工具&#xff0c;设计一个常见信号发生电路&#xff0c;要求&#xff1a; 1. 能够产生锯齿波&#xff0c;方波&#xff0c;三角波&…

【开发篇】十二、缓存框架JetCache

文章目录 0、介绍1、JetCache远程缓存2、JetCache本地缓存3、标准配置文件4、JetCache方法缓存注解--Cached5、Cached4、CacheUpdate5、CacheInvalidate6、CacheRefresh7、缓存统计报告 上篇完成了Spring Cache底层技术的各种切换&#xff0c;但各个技术有各自的优缺点&#xf…

STM32G070RBT6-MCU温度测量(ADC)

1、借助STM32CubeMX生成系统及外设相关初始化代码。 在以上配置后就可以生成相关初始化代码了。 /* ADC1 init function */ void MX_ADC1_Init(void) {/* USER CODE BEGIN ADC1_Init 0 *//* USER CODE END ADC1_Init 0 */ADC_ChannelConfTypeDef sConfig {0};/* USER COD…

【Linux】—— 详解软硬链接

前言&#xff1a; 本期&#xff0c;我将要给大家讲解的是有关 Linux下软硬链接的相关知识&#xff01;&#xff01;&#xff01; 目录 前言 &#xff08;一&#xff09;理解硬链接 1.什么是硬链接 2.创建硬链接 3.硬链接的使用场景 &#xff08;二&#xff09;理解软链接…

区块链(6):p2p去中心化介绍

1 互联网中中心化的服务和去中心化服务的概念介绍 目前的互联网公司大都是中心化的 区块链网络大多是去中心化的 去中心化 2 p2p的简单介绍 java 网络编程:socket编程,netty编程,websoket简单介绍 2.1 节点是如何提供服务的(web编程实现)

目标检测:FROD: Robust Object Detection for Free

论文作者&#xff1a;Muhammad,Awais,Weiming,Zhuang,Lingjuan,Lyu,Sung-Ho,Bae 作者单位&#xff1a;Sony AI; Kyung-Hee University 论文链接&#xff1a;http://arxiv.org/abs/2308.01888v1 内容简介&#xff1a; 1&#xff09;方向&#xff1a;目标检测 2&#xff09;…

jmeterbeanshell调用jsonpath获取对应值

1.jmeter 新建线程组、Java Request、BeanShell Assertion、View Results Tree 2、在BeanShell Assertion中贴入代码&#xff1a; import org.apache.jmeter.extractor.json.jsonpath.JSONManager; import java.util.List; JSONManager js new JSONManager(); String jsonStr…