Mysql中的WITH ROLLUP用法

1.WITH ROLLUP:在group分组字段的基础上再进行统计数据。

例子:首先在name字段上进行分组,然后在分组的基础上进行某些字段统计,表结构如下:

CREATE TABLE `test` (
  `Id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(25) DEFAULT NULL COMMENT ‘标题‘,
  `uid` int(11) DEFAULT NULL COMMENT ‘uid‘,
  `money` decimal(2,0) DEFAULT ‘0‘,
  `name` varchar(25) DEFAULT NULL,
  PRIMARY KEY (`Id`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8mb4;

存几条数据看看:

INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘2‘, ‘国庆节‘, ‘2‘, ‘12‘, ‘周伯通‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘3‘, ‘这次是8天假哦‘, ‘3‘, ‘33‘, ‘老顽童‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘4‘, ‘这是Uid=1的第一条数据哦‘, ‘1‘, ‘70‘, ‘欧阳锋‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘5‘, ‘灵白山少主‘, ‘4‘, ‘99‘, ‘欧阳克‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘7‘, ‘九阴真经创始人‘, ‘3‘, ‘12‘, ‘小顽童‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘8‘, ‘双手互博‘, ‘2‘, ‘56‘, ‘周伯通‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘9‘, ‘销魂掌‘, ‘2‘, ‘19‘, ‘周伯通‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘10‘, ‘蛤蟆功‘, ‘1‘, ‘57‘, ‘欧阳锋‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘11‘, ‘绝杀掌‘, ‘3‘, ‘800‘, ‘小顽童‘);
INSERT INTO `test`.`test` (`Id`, `title`, `uid`, `money`, `name`) VALUES (‘12‘, ‘九阴真经‘, ‘3‘, ‘84‘, ‘老顽童‘);

分组统计:

SELECT name, SUM(money) as money FROM  test GROUP BY name WITH ROLLUP;

可以看到按照name分组后对money求和统计了。上面看到 null 1242, 如何搞个别名字段比如 总金额:1242呢?也可以滴,咱们继续:

coalesce(a,b,c);
参数说明:如果a==null,则选择b;如果b==null,则选择c;如果a!=null,则选择a;如果a b c 都为null ,则返回为null(没意义)。
SELECT coalesce(name, ‘总金额‘),name, SUM(money) as money FROM  test GROUP BY name WITH ROLLUP;

上面可以看出,在数据汇总方面。用途还是很方便滴。

原文地址:https://www.cnblogs.com/phpper/p/9384614.html

时间: 2024-10-17 11:15:13

Mysql中的WITH ROLLUP用法的相关文章

MySQL中的WITH ROLLUP

MySQL中的WITH ROLLUP MySQL的扩展SQL中有一个非常有意思的应用WITH ROLLUP,在分组的统计数据的基础上再进行相同的统计(SUM,AVG,COUNT…),非常类似于Oracle中统计函数的功能,Oracle的统计函数更多更强大. 下面演示单个司机以及所有司机的总行驶里程数和平均行驶里程数: mysql> select name,sum(miles) as 'miles/driver' -> from driver_log group by name with rol

Mysql 中的CASE WHEN 用法

在SELECT语句查询中可以使用CASE WHEN对查询出来的结果,进行一个类似于if else的判断. 具体的用法 1. SELECT a.website_id, b.customer_name, a.website_enddate, c.member_name, d.websitetype_id,            CASE                 WHEN d.websitetype_id=1 THEN 400                WHEN d.websitetype

SQLserver中ISNULL函数与Mysql中IFNULL函数的用法

本文介绍下,sql server中的isnull函数,以及mysql中的ifnull函数,介绍二者的具体用法与区别,有兴趣的朋友可以研究下哦. 先来看SQL Serve的ISNULL函数: ISNULL(check_expression,replacement_value) 1.check_expression与replacement_value的数据类型必须一致. 2.如果check_expression为NULL,则返回replacement_value. 3.如果check_express

MYSQL中replace into的用法

今天在编程的时候,学习了replace into的用法,真的很好用,是insert into的增强版.在向表中插入数据时,我们经常会遇到这样的情况:1.首先判断数据是否存在:2.如果不存在,则插入:3.如果存在,则更新. 在SQL Server中可以这样处理: if not exists (select 1 from t where id = 1)    insert into t(id, update_time) values(1, getdate())  else   update t se

MYSQL中replace into的用法以及与inset into的区别

在向表中插入数据时,我们经常会遇到这样的情况:1.首先判断数据是否存在:2.如果不存在,则插入:3.如果存在,则更新. 在SQL Server中可以这样处理: if not exists (select 1 from t where id = 1)? insert into t(id, update_time) values(1, getdate()) else update t set update_time = getdate() where id = 1 那么 MySQL 中如何实现这样的

mysql中INSTR函数的用法

INSTR(字段名, 字符串) 这个函数返回字符串在某一个字段的内容中的位置, 没有找到字符串返回0,否则返回位置(从1开始) SELECT * FROM tblTopic ORDER BY INSTR( topicTitle, 'ha' ) > 0 DESC SELECT INSTR( topicTitle, 'ha' ) FROM tblTopic mysql中使用instr配合IN排序 将instr结果作为一列,按其排序 select id,1 from world_guide where

MySql 中Join操作的用法

SQL标准中的Join的类型: 首先,设置表employees和department的数据为: 1.inner join - on操作类型 内连接inner join是基于连接谓词将两张表(如A和B)的列组合在一起的,产生新的结果表. 例子: SELECT * FROM employees a inner join department b ON a.department_id = b.department_id 查询结果为: 注意:inner join 可以简写为join,该查询得出的结果为两

mysql 中find_in_set()和in()用法比较

在mysql中in可以包括指定的数字,而find_in_set()用于特定的数据类型. find_in_set 函数使用方法 个例子来说:有个文章表里面有个type字段,它存储的是文章类型,有 1头条.2推荐.3热点.4图文...1,12,13 等等 .现在有篇文章他既是 头条,又是热点,还是图文,type中以 1,3,4 的格式存储.那我们如何用sql查找所有type中有4图文标准的文章呢??这就要我们的 find_in_set 出马的时候到了.以下为引用的内容: select * from

Mysql中select into from用法

原文:http://www.111cn.net/database/mysql/60705.htm 在mysql中用select into from一直报错, 错误:#1327 - Undeclared variable: target_test select into from要求目标表target_table不存在,因为在插入时会自动创建 后来在网上看资料说Mysql不支持select into from语句,所以用其他方法来替代select into from语句: Create targe