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

需求并不难,用程序代码循环处理就可以了。但是后面涉及到打印报表,只能用纯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重复数据查询置为空的更多相关文章
- mysql重复数据查询
假设有表test mysql> select * from test; +----+------+------+ | id | name | sex | +----+------+------+ ...
- 删除MySQL重复数据
删除MySQL重复数据 项目背景 在最近做的一个linux性能采集项目中,发现线程的程序入库很慢,再仔细定位,发现数据库里面很多冗余数据.因为在采集中,对于同一台设备,同一个时间点应该只有一个数据,然 ...
- 【SQL】Oracle和Mysql的分页、重复数据查询(limit、rownum、rowid)
上周三面试题有两道涉及Oracle的分页查询,没有意外地凉了,现在总结一下. · Mysql mysql的分页可以直接使用关键字limit,句子写起来比较方便. 语法: ① limit m,n -- ...
- MySQL:数据查询
数据查询 一.基本查询语句 1.语法:写一行 select{*<字段列表>}//查询的字段,多个字段用逗号分开 from<表1>,<表2>…//数据表名 {//可选 ...
- mysql 大数据 查询方面的测试
---方法1: 直接使用数据库提供的SQL语句---语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N---适应场景: 适用于数据量较少的情况(元组百/千 ...
- mysql 重复数据防止插入:)
insert into table (id, name, age) values(1, "A", 19) on duplicate key update name=values(n ...
- MySql的数据查询
SELECT语句是最常用的查询语句,它的使用方式有些复杂,但功能却相当强大.SELECT语句的基本语法如下: select selection_list//要查询的内容,选择哪些列 from数据表名/ ...
- SpringMVC+Mybatis实现的Mysql分页数据查询
周末这天手痒,正好没事干,想着写一个分页的例子出来给大家分享一下. 这个案例分前端和后台两部分,前端使用面向对象的方式写的,里面用到了一些回调函数和事件代理,有兴趣的朋友可以研究一下.后台的实现技术是 ...
- Python MySQL - 进行数据查询
#coding=utf-8 import mysql.connector import importlib import sys # reload(sys) # sys.setdefaultencod ...
随机推荐
- [bzoj3029] 守卫者的挑战 (概率期望dp)
传送门 Description 打开了黑魔法师Vani的大门,队员们在迷宫般的路上漫无目的地搜寻着关押applepi的监狱的所在地.突然,眼前一道亮光闪过."我,Nizem,是黑魔法圣殿的守 ...
- SpringBoot背景
1.SpringBoot的产生背景:随着spring日益发展,丰富的框架和组件大大简化了java项目开发过程,经过多年的实践,得到了很多人的认可,但是Spring的严重依赖XML配置文件,严重导致项目 ...
- Hexo系列(四) NexT主题配置
Hexo 框架允许我们更换合适的主题,以便于构建不同风格的网站,这里介绍目前最常使用的一款主题之一 -- NexT 一.NexT 安装 在正式开始讲解 NexT 安装之前,我们必须明确以下几个概念: ...
- GOF23设计模式之适配器模式
GOF23设计模式之适配器模式 结构型模式: 核心作用:是从程序的结构上实现松耦合,从而可以扩大整体的类结构,用来解决更大的问题. 分类:适配器模式.代理模式.桥接模式.装饰模式.组合模式.外观模式. ...
- Spring 学习二-----AOP的原理与简单实践
一.Spring AOP的原理 AOP全名Aspect-Oriented Programming,中文直译为面向切面(方面)编程.何为切面,就比如说我们系统中的权限管理,日志,事务等我们都可以将其看 ...
- @Resource与@Autowired区别
每次理解清楚,过段时间就忘了,还是记一下,方便之后再回看. @ Autowired 是spring提供,包含3种自动装配Bean形式 1.@Autowired默认按类型byType匹配,自动装配Bea ...
- [Unit Testing] Set the timeout of a Test in Mocha
Mocha uses a default timeout of 2000 ms. However, if for some reason that does not work for your use ...
- eclipse配置默认的jdk
1.window-preferences-java-Installed JREs-Add-Standard VM-[添加jre6或jre7的路径]
- zoj3822 Domination 概率dp --- 2014 ACM-ICPC Asia Mudanjiang Regional Contest
一个n行m列的棋盘,每次能够放一个棋子.问要使得棋盘的每行每列都至少有一个棋子 须要的放棋子次数的期望. dp[i][j][k]表示用了k个棋子共能占据棋盘的i行j列的概率. 那么对于每一颗棋子,在现 ...
- luogu2761 软件补丁问题 状态压缩最短路径
关键词:状态压缩 最短路径 想不出快速办法,就先考虑考虑暴力.枚举每一种错误分布的情况,然后通过可用的补丁转化为另多种情况,这些情况又转化为更多种情况……我们可以用图来表示这种关系! 状态压缩:每个错 ...