前两天产品有个需求,相同的商品因为价格不同而分开展示,但是明细还是算一条明细,具体区分展示出商品的价格和数量信息,其他重复的商品信息要置空。

  需求并不难,用程序代码循环处理就可以了。但是后面涉及到打印报表,只能用纯sql语句生成。开始自己用了union 写的复杂了一些,后来百度了下文章看到一种实现思路,在此记录一下。下面的内容是根据其思路分析自己修改实现的一个demo,也简单扩展了一点实现功能。

直接上代码好了:

-- ----------------------------
-- Table structure for act
-- ----------------------------
DROP TABLE IF EXISTS `act`;
CREATE TABLE `act`  (
  `id` ) NOT NULL AUTO_INCREMENT COMMENT 'id',
  `name` ) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT 'name',
  `type` ) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT 'type',
  `peple` ) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT 'peple',
  `age` ) NULL DEFAULT NULL COMMENT 'age',
  `sex` ) NULL DEFAULT NULL COMMENT 'sex',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE  CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of act
-- ----------------------------
, , );
, , );
, , );
, , );
, , );
, , );
, , );
, , );
, , );

生成表数据:

下面案列是以type相同与否作为判断条件分组,peple就是type的小写,方便对照观察。后面的Bk结尾的别名字段也是方便对照观察加上的。

实现sql:

SELECT
id,
CASE
               WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.name = a.name
                         GROUP BY type

                       ) THEN name
             WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.name = a.name
                         GROUP BY type

                       ) THEN name
             ELSE ''
        END AS 'name' ,
        CASE WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type

                         GROUP BY type

                       ) THEN type
             WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type
                         GROUP BY type

                       ) THEN type
             ELSE ''
        END AS type,
                 CASE WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.age = a.age

                         GROUP BY type

                       ) THEN age
             WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.age = a.age
                         GROUP BY type

                       ) THEN age
             ELSE ''
        END AS age,
                CASE WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.sex = a.sex

                         GROUP BY type

                       ) THEN sex
             WHEN id in ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.sex = a.sex
                         GROUP BY type

                       ) THEN sex
             ELSE ''
        END AS sex, 

         peple,name as nameBk,age as ageBk,sex as sexBk
FROM    (select * from act order by type,id asc) as b

执行结果:

如果干脆要把任意字段置空(不管是不是重复的)也可以:

SELECT
id,
CASE
               WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type
                         GROUP BY type

                       ) THEN name
             WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type
                         GROUP BY type

                       ) THEN name
             ELSE ''
        END AS name,
        CASE WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type

                         GROUP BY type

                       ) THEN type
             WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type
                         GROUP BY type

                       ) THEN type
             ELSE ''
        END AS type,
                 CASE WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type

                         GROUP BY type

                       ) THEN age
             WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type
                         GROUP BY type

                       ) THEN age
             ELSE ''
        END AS age,
                CASE WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type

                         GROUP BY type

                       ) THEN sex
             WHEN id = ( SELECT MIN(id)
                         FROM   (select * from act) as a
                         WHERE  b.type = a.type
                         GROUP BY type

                       ) THEN sex
             ELSE ''
        END AS sex, 

         peple,name as nameBk,age as ageBk,sex as sexBk
FROM    (select * from act order by type,id asc) as b

执行结果:

上面案例都是以type作为判断分组条件,如果是有多个字段,直接在后面接着增加就可以了。

Mysql重复数据查询置为空的更多相关文章

  1. mysql重复数据查询

    假设有表test mysql> select * from test; +----+------+------+ | id | name | sex | +----+------+------+ ...

  2. 删除MySQL重复数据

    删除MySQL重复数据 项目背景 在最近做的一个linux性能采集项目中,发现线程的程序入库很慢,再仔细定位,发现数据库里面很多冗余数据.因为在采集中,对于同一台设备,同一个时间点应该只有一个数据,然 ...

  3. 【SQL】Oracle和Mysql的分页、重复数据查询(limit、rownum、rowid)

    上周三面试题有两道涉及Oracle的分页查询,没有意外地凉了,现在总结一下. · Mysql mysql的分页可以直接使用关键字limit,句子写起来比较方便. 语法: ① limit m,n -- ...

  4. MySQL:数据查询

    数据查询 一.基本查询语句 1.语法:写一行 select{*<字段列表>}//查询的字段,多个字段用逗号分开 from<表1>,<表2>…//数据表名 {//可选 ...

  5. mysql 大数据 查询方面的测试

    ---方法1: 直接使用数据库提供的SQL语句---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N---适应场景: 适用于数据量较少的情况(元组百/千 ...

  6. mysql 重复数据防止插入:)

    insert into table (id, name, age) values(1, "A", 19) on duplicate key update name=values(n ...

  7. MySql的数据查询

    SELECT语句是最常用的查询语句,它的使用方式有些复杂,但功能却相当强大.SELECT语句的基本语法如下: select selection_list//要查询的内容,选择哪些列 from数据表名/ ...

  8. SpringMVC+Mybatis实现的Mysql分页数据查询

    周末这天手痒,正好没事干,想着写一个分页的例子出来给大家分享一下. 这个案例分前端和后台两部分,前端使用面向对象的方式写的,里面用到了一些回调函数和事件代理,有兴趣的朋友可以研究一下.后台的实现技术是 ...

  9. Python MySQL - 进行数据查询

    #coding=utf-8 import mysql.connector import importlib import sys # reload(sys) # sys.setdefaultencod ...

随机推荐

  1. [jzoj 5781]【NOIP提高A组模拟2018.8.8】秘密通道 (最短路)

    传送门 Description 有一副nm的地图,有nm块地,每块是下列四种中的一种: 墙:用#表示,墙有4个面,分别是前面,后面,左面,右面. 起点:用C表示,为主角的起点,是一片空地. 终点:用F ...

  2. 解决@vue/cli 创建项目是安装chromedriver时失败的问题

    最近在使用新版vue的命令行工具创建项目时,安装chromedriver老是失败,导致后面的步骤也没有进行.网上搜索了一下,全是使用 工作中常见问题汇总及解决方案 npm install chrome ...

  3. fzu 2132

    #include<stdio.h> double h; double tt; void s(long long m,long long n) { long long i,j,sum; j= ...

  4. 转载 - kmp next函数 kmp的周期问题,深入了解kmp中next的原理

    出处:http://www.cnblogs.com/wuyiqi/archive/2012/01/06/2314078.html kmp next函数 kmp的周期问题,深入了解kmp中next的原理 ...

  5. [bzoj1001][BeiJing2006]狼抓兔子_网络流_最小割转对偶图

    狼抓兔子 bzoj-1001 BeiJing2006 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还 ...

  6. POJ 1106

    先判断是否在圆内,然后用叉积判断是否在180度内.枚举判断就可以了... 感觉是数据弱了.. #include <iostream> #include <cstdio> #in ...

  7. python爬虫解决百度贴吧登陆验证码问题

    作为贴吧重度用户,写了个贴吧爬虫脚本 抄了一些别人的代码.记得有个验证码解决的.可是忘了链接了,今天最终自己攻克了. 首先要让登陆须要验证码,不停地登陆就好了...度娘非常快会加上验证码大法的... ...

  8. Tomcat启动时载入某个servlet

    当我们做一个java项目时,有几个功能都须要载入servlet或者实现某个共同的方法,尽管我们一味地在每个功能中依次载入也不是不能够,可是当某个servlet 或者方法被频繁地载入和应用.我们将面向对 ...

  9. JAVA基础实例(一)

    1写一个方法,用一个for循环打印九九乘法表 /** *一个for循环打印九九乘法表 */ public void nineNineMultiTable() { for (int i = 1,j = ...

  10. 【cl】eclipse配置svn

    查看Eclipse版本号 http://jingyan.baidu.com/article/020278118660e81bcd9ce545.html Window>preferences输入S ...