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

MySQL笔记2

目录数据高级操作查询数据字段列表From数据源一.单表数据二.多表数据动态数据where子句groupby子句统计函数,也叫聚合函数.多分组分组排序havi

目录

数据高级操作

查询数据

字段列表

From数据源

一.单表数据

二.多表数据

动态数据

where子句

group by子句

统计函数,也叫聚合函数.

多分组

分组排序

having子句

order by子句 

limit子句:

分页:

运算符

算术运算符: + - * / %

比较运算符: > >= <<= =  <>

逻辑运算符: and or not

in运算符

like运算符




数据高级操作


查询数据

完整的sql查询指令:


select select选项 字段列表 from 数据源 where 条件 group by 分组 having 条件 order by 排序 limit 限制;


select选项:系统该如何对待查询得到的结果

1. all:默认,表示保存所有记录;

2. distinct:去重,去除重复的记录,只表示一条.(所有的字段都相同)

 

可以看到distinct实现去重


字段列表

字段列表有的时候需要从多张表中获取数据,在获取数据的时候,可能存在不同表中有同名字段,需要将同名的命名为不同名的:别名.alias

基本语法:  字段名 [as] 别名 , [ ]代表可有可无,如下所示

 


From数据源

From是为前面的查询提供数据:数据源只要是一个符合二维表结构的数据即可.


一.单表数据

基本语法: from 表名

 这就是两个单表数据


二.多表数据

从多张表中获取数据,

基本语法:  from 表1,表2,表3...

如上是同时查询两张表数据,将两张表所有数据合并输出.在数学上称为笛卡尔积,但是这个结果给数据库造成压力,没有其他意义!应该尽量避免出现笛卡尔积!


动态数据

from后面跟的数据不是一个实体表,而是一个从表中查询出来得到的二维结果表.(子查询)

基本语法:from (select 字段列表 from 表) as 别名;      //必须要有别名

它本身没有数据源,是 从另外一张表查询出来放到这个别名表里面,最终呈现出来了


where子句


用来从数据表获取数据的时候,进行条件筛选.

where的作用就是在拿到一条结果就开始进行判断.判断是否符合条件,符合就保存下来,不符合就舍弃(不放到内存中).

where是通过运算符进行结果比较来判断数据.

注:条件字段比较符号:
=,<,>,>=,<=,!=等比较运算符
多个条件之间可以使用or and等


group by子句

group by表示分组:根据指定的字段,将数据进行分组.分组的目标是为了统计.

分组统计

基本语法:group by 字段名;

如上,group by是为了分组后进行数据统计的.如果只是想看数据显示,那么group by没意义. 

group by将数据按照指定的字段分组之后,只会保留每组的第一条记录.


统计函数,也叫聚合函数.

count():统计每组中的数量.如果统计的目标是字段,则不统计为空即null的字段,如果为*代表统计记录。 

select count(*|字段名) from 表名;一般就直接写*

avg():求平均值    select avg(字段名) from 表名;

sum():求和. select sum(字段名) from 表名;

max()   min()   :  求最值

select max(字段名) from 表名;  select min(字段名) from 表名;

不举例了

综合一下聚合函数,按照班级 统计每班人数,最大年龄,最矮身高,平均年龄:

 这也说明了,group by 是为了分组之后再统计


多分组

将数据按照某个字段进行分组之后,对已经分组的数据进行再次分组.

基本语法:group by 字段1,字段2...;   //先按照字段1排序,之后将结果按照字段2排序,依此类推


分组排序

mysql中,分组默认有排序的功能,按照分组字段进行排序,默认是升序asc. 降序是desc 

基本语法:group by 字段 [asc|desc], 字段2 [asc|desc]...;

我们将上例子全转为降序:


having子句

having的本质和where一样,是用来进行数据条件筛选.

1. having是在group by子句之后,可以针对分组数据进行统计筛选,但是where不行.

实例演示:我们想统计人数大于等于3个人的班级.

 将having换成where 会把报错

注意:where不能使用聚合函数:聚合函数是用在group by分组的时候,where已经运行完毕.

having在group by分组之后,可以使用聚合函数或者字段别名(where是从表中取出数据,别名是在数据进入到内存之后才有的)


  • where语句在droup by语句之前;SQL会在分组之前计算where语句。   
  • having语句在group by语句之后;SQL会在分组之后计算having语句。


order by子句

order by排序子句:根据校对规则对数据进行排序

基本语法:order by 字段[asc|desc];   //asc升序,默认;desc降序

举例:

 

 

order by像group by一样,可以进行多字段排序:先按照第一个字段进行排序,然后按照第二个字段进行排序.

order by 字段1规则,字段2规则;


 


limit子句:

主要用来限制记录数量获取

纯粹的限制获取的数量:从第一条到指定的数量

基本语法:limit 数量;

 


分页:

利用limit来限制获取指定区间的数据

基本语法:limit offset,length; //offset偏移量:从哪开始,length就是具体的获取多少条记录数

注意:mysql中记录从0开始. 

limit 0,2:表示获取前2条记录.    limit 2,2;表示获取第三第四条记录

实例,分页演示:

注意:limit后面的length参数表示最多获取对应数量.但是如果实际数量不够,系统不会强求.


运算符


算术运算符: + - * / %

通常不在条件中使用,而是用于结果运算(select字段中)

 


比较运算符: > >= <<= =  <>

通常用在在条件中限定结果,使用频繁

=: 注意mysql中没有==符号

<=>:相等比较.

 

 特殊应用:就是在字段结果中进行比较运算

如上 字符串&#39;1&#39;==数字1,因为会转化成同类型;返回的结果1代表true,0代表false.

在条件判断的时候,还有对应的运算符:计算区间

Between 条件1 and 条件2;// 请看下例

寻找id在3到5 的学生

 


逻辑运算符: and or not

and-逻辑与:

寻找id >=3 并且 age<15的学生

 

or-逻辑或:

寻找 age>13 或者 id>4 的学生


in运算符

in:在...里面.判断元素是否在1个集合中

基本语法: in (结果1,结果2...) 只要当前条件在结果集中出现过,那么就成立

 

 


like运算符

用来进行模糊匹配(匹配字符串)

基本语法:like ‘匹配模式’


  • _ 匹配当前位置单个字符
  • % 匹配指定位置多个字符

例如,匹配名字以“李”开头的学生信息 &#39;李%&#39;

 


推荐阅读
  • 本文介绍了在MacOS系统上安装MySQL的步骤,并详细说明了如何设置MySQL服务的开机启动和如何修改MySQL的密码。通过下载MySQL的macos版本并按照提示一步一步安装,在系统偏好设置中可以找到MySQL的图标进行设置。同时,还介绍了通过终端命令来修改MySQL的密码的具体操作步骤。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文详细介绍了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特性的实现原理和实际应用方式。 ... [详细]
  • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
  • mysql-cluster集群sql节点高可用keepalived的故障处理过程
    本文描述了mysql-cluster集群sql节点高可用keepalived的故障处理过程,包括故障发生时间、故障描述、故障分析等内容。根据keepalived的日志分析,发现bogus VRRP packet received on eth0 !!!等错误信息,进而导致vip地址失效,使得mysql-cluster的api无法访问。针对这个问题,本文提供了相应的解决方案。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
author-avatar
雪儿babyqueenpb_446
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有