mysql 删除查询语句所选出的数据 SQL查询,用于找出outbox表中memo1字段重复且dt字段不是最新日期的记录

编写一个SQL查询,用于找出outbox表中memo1字段重复且dt字段不是最新日期的记录

批量打印包装箱时,提示有重复N条的处理方法:
–先备份数据库,删除不可逆。查出来,如果就是重复的N条,全选右键 删除
SELECT o.*
FROM outbox o
INNER JOIN (
SELECT memo1, MAX(dt) as max_dt
FROM outbox
WHERE memo1 BETWEEN ‘e7MP73110000001’ AND ‘e7MP73110015300’
GROUP BY memo1
HAVING COUNT(memo1) > 1
) grouped_o ON o.memo1 = grouped_o.memo1
WHERE o.dt < grouped_o.max_dt
AND o.memo1 BETWEEN ‘e7MP73110000001’ AND ‘e7MP73110015300’

–查询箱号特别大的 异常的
select * from outbox o where no>=100 and o.memo1 BETWEEN ‘e7MP73110000001’ AND ‘e7MP73110015300’

删除查询语句所选出的数据

要删除由您提供的查询语句所选出的数据,可以将该查询转换为一个删除语句。原始查询语句选出了outbox表中memo1字段重复、dt字段不是最新时间且memo1值在e7MP73110000001e7MP73110015300范围内的记录。下面是如何将其转换为删除语句:

DELETE o FROM outbox o
INNER JOIN (SELECT memo1, MAX(dt) as max_dtFROM outboxWHERE memo1 BETWEEN 'e7MP73110000001' AND 'e7MP73110015300'GROUP BY memo1HAVING COUNT(memo1) > 1
) grouped_o ON o.memo1 = grouped_o.memo1
WHERE o.dt < grouped_o.max_dt
AND o.memo1 BETWEEN 'e7MP73110000001' AND 'e7MP73110015300'

这个删除语句的逻辑是:

  1. 通过内部联接(INNER JOIN)将outbox表的记录与分组子查询grouped_o相连接。grouped_o子查询找出每个memo1值的最大dt日期,并确保每个memo1至少出现两次。

  2. 然后,根据这个联接的结果,删除那些memo1相同但dt小于最大日期且memo1在指定范围内的记录。

在执行此删除操作之前,请确保您有完整的数据备份。删除操作是不可逆的,一旦执行,被删除的数据将无法恢复。如果可能的话,建议先在测试环境中运行此SQL语句以确保其按预期工作。

为什么DELETE o FROM 一定要加上o呢?

在SQL语句中使用DELETE o FROM的原因是为了指定要从哪个表中删除记录,尤其是在涉及到连接多个表的情况下。

当你使用DELETE FROM语句删除数据时,通常的形式是DELETE FROM table_name,这在处理单个表时非常直接和清晰。但是,当你的删除操作涉及到基于多表连接的复杂查询时,就需要明确指出要从哪个表中删除记录。

在提供的例子中:

DELETE o FROM outbox o
INNER JOIN ...

ooutbox表的别名(alias),这是在查询中为了简化引用而给表指定的短名。在DELETE语句中指定o表示你想从与别名o关联的outbox表中删除记录。

如果不指定o,SQL服务器可能不会清楚你打算从哪个表中删除数据,尤其是当查询涉及多个表时。通过明确指定o,你告诉数据库确切地从outbox表中删除那些满足联接条件的记录。

总结来说,DELETE o FROM在涉及多表连接的复杂删除操作中用于明确指定要从哪个表中删除记录,以避免混淆或错误。

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

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

相关文章

LeetCode-数组-双指针-中等难度

文章目录 双指针1. 删除有序数组中的重复项&#xff08;入门&#xff09;1.1 题目描述1.2 解题思路1.3 代码实现 2. 删除有序数组中的重复项 II&#xff08;简单&#xff09;2.1 题目描述2.2 解题思路2.3 代码实现 3. 移动零&#xff08;简单&#xff09;3.1 题目描述3.2 代码实…

Hive的时间处理函数from_unixtime和unix_timestamp

一、概述 hive时间处理函数from_unixtime和unix_timestamp的实现以及实例&#xff0c;从而方便后续的时间处理。 二、具体功能实现 1.unix_timestamp(date[, pattern])&#xff1a; 默认的时间格式是yyyy-MM-dd HH:mm:ss&#xff0c;如果日期不是这种格式无法识别&#xff…

【技术选型】clickhouse vs starRocks

比对结论 如果只能单机部署的话&#xff0c;clickhouse基本无敌。 如果集群化&#xff0c;starRocks可以替换clickhouse&#xff0c;但支持的函数会相对少一些&#xff08;clickhouse有不少自定义函数&#xff09; 信息比对 功能clickhousestarRocksjoin大表关联容易OOM对jo…

AQS应用之BlockingQueue详解

概要 AQS全称是 AbstractQueuedSynchronizer&#xff0c;中文译为抽象队列式同步器。BlockingQueue&#xff0c;是java.util.concurrent 包提供的用于解决并发生产者 - 消费者问题的最有用的类&#xff0c;它的特性是在任意时刻只有一个线程可以进行take或者put操作&#xff0…

MySQL之导入导出远程备份

目录 一. navicat导入导出 二. mysqldump命令导入导出 导入 导出 三. load data infile命令导入导出 导入 导出 四. 远程备份 导入 导出 思维导图 一. navicat导入导出 导入&#xff1a;右键➡运行SQL文件 导出&#xff1a;选中要导出的表➡右键➡转储SQL文件➡数据和结…

C# Emgu.CV4.8.0读取rtsp流录制mp4可分段保存

【官方框架地址】 https://github.com/emgucv/emgucv 【算法介绍】 EMGU CV&#xff08;Emgu Computer Vision&#xff09;是一个开源的、基于.NET框架的计算机视觉库&#xff0c;它提供了对OpenCV&#xff08;开源计算机视觉库&#xff09;的封装。EMGU CV使得在.NET应用程序…

x-cmd pkg | vhs - 将终端的操作过程录制成视频文件的终端录制工具

目录 简介首次用户声明式录制脚本其他功能竞品和相关作品进一步阅读 简介 vhs 是一个命令行录制工具&#xff0c;用于将终端的操作过程录制成视频文件。是由 Charmbracelet 团队使用 Go 开发的&#xff0c;首个版本发布于 2022 年 10 月。开源不到一个月有接近 8k 的 star。 …

Kubernetes (八) 金丝雀发布

一. 金丝雀发布作用&#xff1a; 金丝雀发布是指在生产环境中逐步推出新版本应用程序&#xff0c;只在一小部分用户或流量中使用该版本&#xff0c;并根据反馈逐步扩…

收到的字符串写入xml并且将这个xml写入.zip文件中

文章目录 1、将数据写入xml文件WriteToXmlFile2、将xml文件写入zip压缩文件AddToZip3、组合起来4、使用到的头文件和动态库 1、将数据写入xml文件WriteToXmlFile void CSMSLoginDlg::WriteToXmlFile(const std::string& responseData, const std::string& xmlFileName…

计算机为什么有趣?哪些地方有趣?为什么学习四则运算简单,学习微积分却很难?导数是微分吗?

计算机为什么有趣&#xff1f;哪些地方有趣&#xff1f; 计算机之所以有趣&#xff0c;主要是因为它们具有无限的可能性和创造力。这里有几个方面可以帮助你理解为什么计算机这么有趣&#xff1a; 解决问题的工具&#xff1a;想象一下&#xff0c;你有一个拼图&#xff0c;计算…

PostgreSQL 支持的字段类型

PostgreSQL 支持多种字段类型&#xff0c;以下是 PostgreSQL 13 版本中支持的所有字段类型&#xff1a; 数值类型&#xff1a; smallint&#xff1a;小整数类型。integer&#xff1a;整数类型。bigint&#xff1a;大整数类型。decimal&#xff1a;精确小数类型。numeric&#x…

Redis(三)持久化

文章目录 RDB&#xff08;Redis Database&#xff09;自动触发保存频率修改dump文件保存路径修改文件保存名称dump恢复 手动触发save![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a56fdff44aee4efa96c2ce3615b69dc1.png)bgsave 优劣优点缺点 检查修复dump文件会触…

手把手教你使用cubemx配置串口

重写fput函数 #include <stdio.h>#ifdef __GNUC__#define PUTCHAR_PROTOTYPE int _io_putchar(int ch)#else#define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)#endif /* __GNUC__*//*******************************************************************brief R…

安全狗获评CCIA“2023年度先进会员单位”

1月4日&#xff0c;2023年度中国网络安全产业联盟会员大会暨理事会在北京成功举办。 作为国内云原生安全领导厂商&#xff0c;安全狗也受邀出席此次活动。 厦门服云信息科技有限公司&#xff08;品牌名&#xff1a;安全狗&#xff09;创办于2013年&#xff0c;是国内领先的云…

你的企业知识库该更新啦,这样搭建高效又轻松

很明显&#xff0c;企业知识库已经成为我们工作中必不可少的资源&#xff0c;它的价值已经不言而喻&#xff0c;无论是促进团队合作&#xff0c;还是帮助我们更有效地找到收集和使用知识&#xff0c;知识库都发挥着重要的作用&#xff0c;然而&#xff0c;你的企业知识库已经过…

springboot——消息中间件

消息的概念 从广义角度来说&#xff0c;消息其实就是信息&#xff0c;但是和信息又有所不同。信息通常被定义为一组数据&#xff0c;而消息除了具有数据的特征之外&#xff0c;还有消息的来源与接收的概念。通常发送消息的一方称为消息的生产者&#xff0c;接收消息的一方称为…

OV5640 摄像头的图像平滑处理

如图所示&#xff0c;这是整个视频采集系统的原理框图。 上电初始&#xff0c;FPGA 需要通过 IIC 接口对 CMOS Sensor 进行寄存器初始化配置。这些初始化的基本参数&#xff0c;即初始化地址对应的初始化数据都存储在一个预先配置好的 FPGA 片内 ROM中。在初始化配置完成后&…

遥感影像-语义分割数据集:云数据集详细介绍及训练样本处理流程

原始数据集详情 简介&#xff1a;该云数据集包括150张RGB三通道的高分辨率图像&#xff0c;在全球不同区域的分辨率从0.5米到15米不等。这些图像采集自谷歌Earth的五种主要土地覆盖类型&#xff0c;即水、植被、湿地、城市、冰雪和贫瘠土地。 KeyValue卫星类型谷歌Earth覆盖区…

spring redis 连接和连接池配置 使用

spring redis 连接和连接池配置 使用 redis的使用方式方法有很多&#xff0c;我这里只用了这一种 jar包 redis <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.5.2</version> </dep…

树莓派中配置mDNS服务

在树莓派上配置mDNS服务通常涉及使用Avahi守护进程&#xff0c;它是Linux系统中最常用的mDNS实现之一。为了在树莓派上配置mDNS服务&#xff0c;请按照以下步骤操作&#xff1a; 安装 Avahi: 打开树莓派的终端&#xff0c;确保你的系统是最新的&#xff0c;然后安装 Avahi 和它…