一、背景最近在和系统模块做数据联调,其中有一个需求是将两个角色下的相关数据对比后将最新的数据返回出去,于是就想到了去重,再次做一个总结。 二、数据去重三种方法使用1.通过MySQL DISTINCT:去重(过滤重复数据)1.1.在使用 mysql SELECT 语句查询数据的时候返回的是所有匹配的行。 SELECT t.age FROM t_user t可以看到查询结果返回了 10 条记录,其中有一些重复的 age 值,有时出于对数据分析的要求,需要消除重复的记录值。 1.2.DISTINCT 关键字指示 MySQL 消除重复的记录值。 语法格式为: SELECT DISTINCT <字段名> FROM <表名>;由运行结果可以看到,这次查询结果只返回了 5 条记录的 age 值,且没有重复的值。 ps: 其中,“字段名”为需要消除重复记录的字段名称,多个字段时用逗号隔开。 使用 DISTINCT 关键字时需要注意以下几点: DISTINCT 关键字只能在 SELECT 语句中使用。 在对一个或多个字段去重时,DSTINCT 关键字必须在所有字段的最前面。 如果 DISTINCT 关键字后有多个字段,则会对多个字段进行组合去重,也就是说,只有多个字段组合起来完全是一样的情况下才会被去重。 2.group by3.row_number窗口函数语法格式为: row_number() over (partition by <用于分组的字段名> order by <用于组内排序的字段名>)项目使用的去重: select * from (select t.*,row_number() over(partition by t.children_id order by t.update_time DESC) rnfrom mdm_data_authority_view_info t where t.DATA_CLASS_ID = '分类id' AND t.DATA_ROLE_ID IN ( '角色id', '角色id' )) where rn = 1; 三、总结到此这篇关于详解mysql数据去重的三种方式的文章就介绍到这了,更多相关mysql数据去重内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! |
本文实例为大家分享了C# GDI+实现时钟表盘的具体代码,供大家参考,具体内容如下一、...
目录一、正则表达式应用举例1、C#校验合法性:2、C#限制输入3、正则表达式匹配闭合HTM...
本文实例为大家分享了C#实现图形界面的时钟的具体代码,供大家参考,具体内容如下秒针...
目录一、ObjectContext对象上下文1、ObjectContext和DbContext的对比2、ObjectContext...
IronPython是一种在 .NET及 Mono上的 Python实现,由微软的 Jim Hugunin所发起,是一...
本文实例为大家分享了使用C#写一个时钟,供大家参考,具体内容如下时钟是这样的一共使...
一、介绍Topshelf是一个开源的跨平台的宿主服务框架,支持Windows和Mono,只需要几行...
本文实例为大家分享了C#实现动态数字时钟和日历的具体代码,供大家参考,具体内容如下...