热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

MySQL创建字段+数据处理函数+汇总数据(聚集函数)+分组数据_MySQL

本文部分文字描述转自MySQL必知必会,旨在reviewMySQL创建字段数据处理函数汇总数据(聚集函数)分组数据的基础知识
  【0】README 0.1)本文部分文字描述转自“MySQL 必知必会”,旨在review“MySQL创建字段+数据处理函数+汇总数据(聚集函数)+分组数据” 的基础知识;

  【1】创建计算字段 1)problem+solution

  1.1)problem:存储在表中的数据都不是应用程序所需要的。我们需要直接从数据库中检索出转换,计算或格式化过的数据; 1.2)solution:这就是计算字段发挥作用所在了, 计算字段是运行时在 select语句内创建的;

  2)字段定义:基本上与列的意思相同,经常互换使用,不过数据库列一般称为列,而术语字段常用在计算字段的连接上; Attention)建议在数据库服务器上完成对数据的转换和格式化工作,因为相比于客户机,数据库服务器完成这些操作要快得多;

  3)拼接字段

  3.1)拼接:将值联结到一起构成单个值(使用 concat() 函数来拼接两个列);

  

\

  3.2)删除数据右侧多余空格来整理数据: 这可以通过RTrim()函数来实现,(不区分大小写,即rtrim()函数),当然也有ltrim() 函数 和 trim() 函数;

  

\

  4)执行算术能力

  

\

  Attention)MySQL中的now() 函数,返回当前日期和时间;

  

\

  【2】使用数据处理函数 1)上一章中的 rtrim() + ltrim() + trim() 就是一个利用函数的荔枝; Attention)能运行在多个系统上的代码称为可移植性;相对来说,多数SQL语句是可移植的,但函数的移植性却不强,几乎每种DBMS 的实现都支持其他实现不支持的函数;为了代码的可移植性,许多SQL 程序员不赞成使用特殊实现的功能;如果你决定使用函数,应该保证做好代码注释;(干货——不建议在MySQL中使用函数,因为其函数的可移植性不高); 2)文本处理函数

  

\

  

\

  3)日期和时间处理函数

  

\

  Attention)首先需要注意的是MySQL 使用的日期格式。无论你什么时候指定一个日期,不管是插入还是更新表值还是用where子句进行过滤,日期必须为格式 yyyy-mm-dd, 这是首选的日期格式,因为它排除了多义性(如 04/05/06 是 2006年5月4日还是2006年4月5日或2004年 5月6日呢?) problem+solution)

  

\

  problem)如上图所示,对于datetime 类型的 deal_time ,where deal_time='2016-05-10' 检索失败; solution)指示MySQL 仅将给出的日期与列中的日期部分进行比较,而不是将给出的日期和整个列值进行比较。为此,必须使用Date()函数;

  

\

  Attention)date() 函数 和 time()函数都是在 MySQL4.1.1引入的;

  

\

  4)还有一种日期需要比较。如,想要检索出 2005年9月下的所有订单,怎么办?(between ... and ... 语句)

  

\

  

\

  5)数值处理函数

  

\

  【3】汇总数据 1)聚集函数:如确定表中行数;获得表中行组的和;找出表列的最大值,最小值和平均值;

  1.1)聚集函数定义:运行在行组上, 计算和返回单个值的函数;

  

\

  1.2)avg()函数

  

\

  Attention)NULL值:avg() 函数忽略列值为null 的行;

  1.3)count() 函数 的两种用法

  func1)使用count(*)对表中行的数目进行计数,不管表列中包含的是空值(NULL)还是非空值;

  func2)使用count(column)对特定列中具有值的进行计数,忽略NULL 值;

  

\

  1.4)max() 函数 和 min() 函数 + sum()函数

  

\

  2)聚集不同值:以上5个聚集函数都可以如下使用:

  2.1)对所有的行执行计算,指定all 参数或不给参数(因为all 是默认行为); 2.2)只包含不同的值,指定distinct 参数;

  看个荔枝)考虑各个不同的price(distinct==不同的)

  

\

  3)组合聚集函数

  

\

  【4】分组数据(group by 和 having 子句) 1)数据分组:统计每个供应商提供的产生数量; 2)创建分组:分组是在select 语句中通过 group by 子句创建的;

  

\

  3)在具体使用 group by 子句前,需要知道一些重要的规定(rules)

  r1)group by 子句可以包含任意数目的列,这使得对分组可以嵌套,为数据分组提供更细致的控制(也即 group by column1, column2==先按照column1进行分组,再按照column2进行分组); r2)如果在group by 子句中嵌套了分组,数据将在最后规定的分组上进行汇总。换句话说,在建立分组时,指定的所有列都一起计算; r3)group by子句中列出的每个列都必须是检索列或有效的表达式。如果在select中使用表达式,则必须在group by子句中指定相同的表达式,不能使用别名; r4)初开聚集计算语句外,select语句中的每个列都必须在 group by 子句中给出;(干货规定) r5)如果分组列中具有null 值, 则null 值将作为一个分组返回。 如果列中有多行NULL 值,它们将分为一组; r6)group by 子句必须出现在 where 子句之后,order by 子句之前;(干货——group by 子句在 where子句和order by 子句的位置)

  Attention)使用rollup:使用with rollup 关键字,可以得到每个分组以及每个分组汇总级别(针对每个分组)的值;

  4)过滤分组

  4.1)过滤分组使用 having子句进行处理; 4.2)where子句和having子句的区别(Difference):

  D1)where过滤行,而having 过滤列;

  D2)where 在数据分组前进行过滤,而having在数据分组后进行过滤;(干货——这是where 和having一个重要的区别)

  

\

  Attention)having子句的位置:having子句过滤是基于group by的,它在group by子句的后面 ; 看个荔枝)证明where 在数据分组前进行过滤,而having在数据分组后进行过滤;(干货——这是where 和having一个重要的区别)

  

\

  5)分组和排序(group by 和 order by)

  5.1)group by 和 order by的不同

  

\

  5.2)不要忘记group by:一般在使用 group by 子句时,应该也给出order by子句。这是保证数据正确排序的唯一方法;

  

\

  6)select 子句的顺序

  

\

  

\

推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文详细介绍了云服务器API接口的概念和作用,以及如何使用API接口管理云上资源和开发应用程序。通过创建实例API、调整实例配置API、关闭实例API和退还实例API等功能,可以实现云服务器的创建、配置修改和销毁等操作。对于想要学习云服务器API接口的人来说,本文提供了详细的入门指南和使用方法。如果想进一步了解相关知识或阅读更多相关文章,请关注编程笔记行业资讯频道。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
author-avatar
Ray依依
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有