Mysql查询(笔记二)
1.两结构相同的表数据间移植
Inset into 表一
Select 字段1,字段2,....字段n from表二
建立数据库时设置数据库编码
create database 数据库名 charset uft8
模糊查询时
%(任意字符任意个数)
_(单个字符)
2.聚合函数使用时必须有group by给定分组条件
比如有一个表

求平均成绩是用聚合函数avg()时必须制定此函数作用的范围依据
3.分组,排序,再次筛选,取几条执行顺序
Where>group by >having>order by >limit
门及2门以上同学的平均分和不及格科目数
方法一:分步查询
先查出2门及2门以上不及格学生是谁
然后再查这些同学的平均分,需要2个select语句
select name from stu where score<60 group by name having count(name)>=2
便得到表
|
name |
|
张三 |
|
李四 |
注意sql的执行顺序
先执行select name from stu where score<60
会得到表2:
|
name |
|
张三 |
|
张三 |
|
李四 |
|
李四 |
|
王五 |
之后再分组和再筛选
但要注意虽然group by在having前,但group by是作为having的筛选分组条件的
然后在表2中having筛选即得
第二步:
找到这些学生后,在把学生名最为查询条件再次筛选,因为第一步筛选掉了及格的了的成绩,结果破坏了数据的原始性,所以还得进行一次筛选
select name,avg(score) from stu where name in (select name from stu where
score<60 group by name having count(name)>=2) group by name;
方法二:利用select后可以直接是判断式及本题特点
分析:首先运行sql查询
select name ,score<60 from stu;
得到下表3:
|
name |
Score<60 |
|
张三 |
0 |
|
张三 |
1 |
|
张三 |
1 |
|
李四 |
1 |
|
李四 |
1 |
|
王五 |
1 |
在select后的字段或条件mysql会依次与表中的数据对比,如score<60会拿60逐一与表中的score值比较
比如字段name没有要比较的值就显示它在表中的值
从表三发现:sum(score<60)的值就是不及格科目数
于是
select name ,avg(score),sum(score<60) as gk from stu group by name having
gk>=2;
聚合函数的执行时同时进行
得到结果表:

显然方法二比一更简洁高效
未完待续....!
Mysql查询(笔记二)的更多相关文章
- MySQL学习笔记(二)—查询
一.多表连接查询 新建两张表t_user.t_order. 1.内连接 返回满足条件的所有记录. (1)显式内连接 使用inner join关键字,在on ...
- MySQL学习笔记(二):MySQL数据类型汇总及选择参考
本文主要介绍了MySQL 的常用数据类型,以及实际应用时如何选择合适的类型. ******几个通用的简单原则:******* 1. 更小的通常更好.但是要确保没有低估需要存储的值的范围,如果无法确定 ...
- MySQL学习笔记(二)
连接与断开服务器 应该以下面的方式连接MySQL服务器,而不是将密码以明文方式输入连接. C:\> mysql -h host -u user -pEnter password: ******* ...
- MySQL数据库笔记二:数据类型及数据库操作
三.MySQL数据库数据类型 MySQL数据库中支持多种数据类型:数值型.字符型.日期型 常用的数据类型: 1.整型 int:整形,存储整数 int(M):M表示预期值.与存储大小和数值的范围无关. ...
- sql分类及基本sql操作,校对规则(mysql学习笔记二)
sql针对操作对象分为不同语言 数据操作(管理)语言 DML或者将其细分为 ( 查询 DQL 管理(增,删,改) DML) 数据定义语言(对保存数据的格式进行定义) DDL 数据库控制语言(针对数 ...
- MySQL学习笔记二
Ø function 函数 函数的作用比较大,一般多用在select查询语句和where条件语句之后.按照函数返回的结果, 可以分为:多行函数和单行函数:所谓的单行函数就是将每条数据进行独立的计算,然 ...
- mysql学习笔记二 —— 权限体系
要点: 1.MySQL的API2.MySQL的相关文件3.MySQL的权限体系 1.MySQL的API 应用程序接口 (application program interface) 1.1 命令行中的 ...
- MySQL 学习笔记 二
Ø function 函数 函数的作用比较大,一般多用在select查询语句和where条件语句之后.按照函数返回的结果, 可以分为:多行函数和单行函数:所谓的单行函数就是将每条数据进行独立的计算,然 ...
- MySQL学习笔记二:权限管理
1. 创建和删除用户,mysql中的用户是由用户名和主机名来确定的 create user "user_name@host_name" identified by passwd; ...
随机推荐
- springmvc的3中路径风格
1.导入相应的jar包,文件放置情况 2.web.xml <?xml version="1.0" encoding="UTF-8"?> <we ...
- XEP-0079
XEP-0045: 多用户聊天 摘要: 本文定义了一个XMPP协议扩展用于多用户文本会议.即多个XMPP可以在一个房间或频道互相交流信息, 类似互联网中继聊天系统(IRC).还有标准聊天室功能如聊天室 ...
- 【转】windows和linux间共享互传文件
原文:http://blog.guorunmin.cn/2015/09/16/windows%E5%92%8Clinux%E9%97%B4%E5%85%B1%E4%BA%AB%E4%BA%92%E4% ...
- Goldengate trial队列维护
查看进程信息: Info replicat_name $Info replicat_name showch 注: 可以查看到详细的关于checkpoint的信息,用于查看GoldenGate进程处 ...
- oracle 表空间管理
1.创建表空间 03:01:55 sys@ORADB11G> create tablespace TSPITR datafile '/u01/app/oracle/oradata/TSPITR0 ...
- 紧张:飞测独家のJmeter秘籍,限量发放(续篇2)
飞测说:一些朋友问,我如何使用获取资料(点击这里获取)?小怪我花了点时间在这里介绍下该资料的功能和意义,另外也整理了一篇操作指引文档. 1.fiddler导出jmx格式的dll文件V4.0版本 功能: ...
- Unity项目在亚马逊KindleFire设备上旋转不正确的解决方案
前提: 在亚马逊设备上,总部要求发布的版本必须使用LandscapeLeft方向.按照经验,在UnityPlayerSettings中设置Orientation即可. 问题表现: ...
- SSH Secure Shell Client的傻瓜式使用方法
说明:本记录仅是使用此软件的一种简单的操作方式,如果想深入研究,请做如下三件事: 1)到其官网了解她的前世今生 2)下载她.安装她.操作她(这一步需要不断的尝试.不断的深入.不断的探索,当然最好理论结 ...
- h5 吸顶效果 顶部悬浮
window.onscroll = function(){ var scrollTop = document.documentElement.scrollTop || document.body.sc ...
- leetcode 8
string类型转换为int类型,需要考虑不同的转换情况. “ 04” 转换结果 4: “ 4 43” 转换结果 4: “a@12 ” 转换结果 0: “12a” ...