MYSQL过滤表中某几个字段重复的数据

MYSQL过滤表中某几个字段重复的数据,第1张

场景:表中包含有group_id,worker_id,status字段,查询这三个字段是否存在重复的数据。

查找某个人在某个班组内存在多个status为0的数据

查找某个人在某个班组内存在多个status为0的数据,将最小的id选出来

查找某个人在某个班组内存在多个status为0的数据,将最小的id选出来,并设置status为1

将查询查询结果作为where in的条件,需要select的结果再通过一个中间表select多一次,否则会报You can't specify target table for update in FROM clause。

复审表通过一次自连接筛选出最大值后再做关联

SELECT

花名册.工号,

花名册.姓名,

取证情况.证书信息,

复审情况F.复审时间

FROM

花名册

LEFT JOIN 取证情况 ON 花名册.工号 = 取证情况.工号

LEFT JOIN (

SELECT 复审情况.* FROM 复审情况 

INNER JOIN

(SELECT MAX(复审时间) 复审时间,工号 FROM 复审情况 GROUP BY 工号) 复审情况2

ON 复审情况.复审时间=复审情况2.复审时间 AND 复审情况.工号=复审情况2.工号

) 复审情况F ON 花名册.工号 = 复审情况F.工号

这是一个大题目,这里只能简单讲解一下。SQL查询的筛选就是实现从一个或多个父记录行集合里筛选出所需要的子记录行集合。

数据库引擎具体的筛选机制是相当复杂的,除非您要成为一个数据库管理系统的开发工程师,一般人没有必要去了解它。当我们需要筛选记录时将筛选逻辑的表述语句提交给数据库引擎去执行就可以了,只要描述这些筛选逻辑语句的语法正确,那么数据库引擎就会忠实地执行并返回相关的结果。

SQL语言里有多种主要方式来筛选记录。

其一是利用where子句设置筛选准则,这是最常用和最重要的筛选方式。我们知道数据库表实际上是二维表,其横向坐标是字段(属性),纵向坐标比较特别,不像电子表格excel它没有固定的行号,纵向定位必须依赖各个字段的字段值(属性值)。因此筛选准则实际就是规定字段值(或者基于字段值的计算表达式)满足(或不满足)某个或多个条件,既可以是精确满足的(使用=号)也可以模糊满足的(使用like运算符)。筛选可以针对单字段也可以针对多字段,我们可以通过逻辑与、逻辑或连接多个筛选条件。

其二是利用表间连接来方式来筛选记录,包括左连接、右连接、对等连接、自连接等,这种连接方法主要是用于筛选出两个记录集之间的交集或非交集。

其三是利用子查询筛选记录,包括[ANY | ALL | SOME]子查询、in子查询、exists子查询等等,其作用跟第二种类似。

当然还有Group、分组里的having子句、distinct关键字、limit等关键字、正则表达式等等方式都可以用于筛选记录,内容相当丰富,筛选可以通过一种或多种方式组合实施,以满足千变万化的筛选需求。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8416739.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-16
下一篇 2023-04-16

发表评论

登录后才能评论

评论列表(0条)

保存