关于mysql的初步学习 (二)

关于mysql(一)遗留下的一个小小的额问题。

就是进行按照性别进行分组查询的时候 既要统计人数又要统计起对应的姓名和更该“sex”字段对应的名称。

以前的方法人数创建了俩个字段进行了显示如下图所示:

起初对于group by的使用并不是太了解 今天看到教程之后,才恍然大悟:

于是有了下面结果

简化了求和的操作。精简了一下。 count(column_name) 里面的参数可以是任何一个值。

到这里为止,上次遗留的问题就完美解决了。 感觉还是得多看看基础知识。多练练才好。

   今天在继续学习的时候。发现在此基础还可以进一步的深挖,比如说计算数量的总和,平均值等等。目前看到的是 with rollup 。其实还有其他的函数也可以使用 比如说  with cube和grouping。这两个暂不介绍。下面以 with rollup 进行简单的实验:

使用 with rollup  在分组的统计数据的基础上再对统计的数据进行相同的统计(SUM,AVG,COUNT…)。

            可以说是对你使用的函数所求的值在再进行对应的函数操作,并生成新的记录。这里就是求和操作。

            但是有个小细节: 我们 group by 的字段 会生成一个null值,在你查询的其他字段 ,均会进行相应的统计操作。比如说这边  userlist 和 num 分别进行了相加,这对于实际应用的业务逻辑有更大的好处。

上述结果产生的 新的统计记录,新增了 null值。mysql有个函数可以对此进行处理, coalesce(a,b,c) :

结果如下: 会带来一个 警告 使用这个函数 。 另外一个警告是case when 里面使用了中文

但总感觉太复杂没必要,进行 性别的转换,精简了下:

也就是说 查询出来了 男女分别多少人 以及总数。

            最后说明下:

          1、 group by 的字段可以有多个。比如说查询 部门和职位进行分组,计算每个部门,每个职位的工资平均值等等。以及搭配 with rollup 和其他函数的操作。

           下一次进行详细的学习。

       

时间: 2024-10-03 13:38:44

关于mysql的初步学习 (二)的相关文章

Jquery Easy UI初步学习(二)datagrid的使用

第一篇学的是做一个管理的外框,接着就是数据datagrid绑定了,这里我用asp.net mvc3来做的,主要就是熟悉属性.方法. 打开easyui的demo 就可以看到如下一段代码: 和上篇一样class="easyui-datagrid", data-options="...",这是一样的,其他我在网上查了查,并做了整理 DataGrid 属性 参数名 类型 描述 默认值 title string Datagrid面板的标题 null iconCls strin

关于mysql的初步学习 (四)

继续深入学习下 group by的使用: 它的语法是   select             column_name1,column_name2,...,function(column_name)      from             table_name      where             column_name operator valuue     group by            column_name1,column_name2,... 比如说:求一个班上的男女

MySQL命令学习(二)

(13)where字句操作符 =            等于 <>          不等于 !=           不等于 <            小于 >            大于 >=          大于等于 BETWEEN          在指定的两个值之间 例如: 找出学号是0007到0009之间的学生记录(不包括0009)? SELECT* FROM student_info WHERE stu_id BETWEEN 1001101620007 AND

[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)

[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二) Date  周六 10 一月 2015 By 钟谢伟 Category website development Tags asp.net / mvc4 相关资源 ibatis manual pro git 廖雪峰的官方网站 BookMS-V1.0 上一篇链接 任务简介 开发工具:VS2010 项目框架:MVC4 浏览器:Chrome 数据库ORM框架:iBatis.net 数据库:mysql 后端开

LinQ的初步学习与总结

嘿嘿,说起来ORM和LinQ,就感觉离我好遥远的,在学校是没有学习的,所以总感觉学习了LinQ就是大神,现在嘛,终于也体会一点,感觉LinQ只是初步学习,没有太难,当然以后使用在项目中就没有这样的简单啦,下面就全面的总结一下LinQ的其中一部分,LinQ有三部分:LinQ TO Object:LinQ TO SQL ;LinQ TO XML.而在这里我先来总结一下LinQ TO Object的学习吧 一.初步认识LinQ to Object static void Main(string[] a

屌炸天实战 MySQL 系列教程(二) 史上最屌、你不知道的数据库操作

此篇写MySQL中最基础,也是最重要的操作! 第一篇:屌炸天实战 MySQL 系列教程(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:屌炸天实战 MySQL 系列教程(二) 史上最屌.你不知道的数据库操作 本章内容: 查看\创建\使用\删除 数据库 用户管理及授权实战 局域网远程连接法 查看\创建\使用\删除\清空\修改 数据库表(是否可空,默认值,主键,自增,外键) 表内容的增删改查 where条件.通配符_%.限制limit.排序desc\asc.连表join.组合union 查

初步学习C++:C++的基本概念

开始学习C++,先从最基本的概念开始,让自己有一个系统的知识概念. 1.对象: 在面向对象程序设计中,对象是描述其属性的数据以及对这些数据施加的一组操作封装在一起构成的统一体.对象可以认为是:数据+操作(对象所能完成的操作表示它的动态行为,也成为方法). 2.类: 在面向对象程序设计中,类就是具有相同的数据和相同的操作的一组对象的集合,类是对具有相同数据结构和相同操作的一类对象的描述. 3.消息: 在面向对象程序设计中,一个对象向另一个对象发出的请求被称为"消息".当对象接收到发向它的

状态保持以及AJAX的初步学习

嘿嘿,今天学习的有点迷茫哦,主要学习把验证码使用在登录页面时间的一些逻辑,学习这个时间并没有那么的迷惑哦,可是自己写程序时间倒是有点反应迟钝,不过还好总是在最后搞清楚啦,另外就是一步一步的学习是接近项目期,今天下午学习了ajax,这个使用javascript写起来还是蛮麻烦的,嘿嘿,但是使用jquery实现是非常的简单的,不知道是不是由于我刚接触的原因,下面来总结一下今天学习的内容,感觉今天学习的还是很有必要详细总结的,因为在以后的项目中还是经常会使用的. 一.状态保持 1.cookie的添加与

MySQL Innodb 架构学习

一.MySQL后台线程   1.Master Thread 核心后台线程,主要负责将缓冲池的数据异步刷新到磁盘.例如脏页的刷新,插入缓冲的合并,undo 页的回收等. 1)每秒一次的操作: 日志缓冲刷新到磁盘,即使该事务还没有提交.该操作总是会发生,这个就是为了再大的事务,提交时间都很短. 当IO压力很小时(1s内发生的IO次数小于5% innodb_io_capacity)合并5% innodb_io_capacity 的插入缓冲. 当脏页比例大于 innodb_max_dirty_pages