mysql查询笔记_Mysql查询(笔记二)

1.两结构相同的表数据间移植

Inset into 表一

Select 字段1,字段2,....字段n from表二

建立数据库时设置数据库编码

create database 数据库名 charset uft8

模糊查询时

%(任意字符任意个数)

_(单个字符)

2.聚合函数使用时必须有group by给定分组条件

比如有一个表

0ed394c822d9cf8c651248bfda9e9bd5.png

求平均成绩是用聚合函数avg()时必须制定此函数作用的范围依据

3.分组,排序,再次筛选,取几条执行顺序

Where>group by >having>order by >limit

4.如上表要求查询2门及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;

聚合函数的执行时同时进行

得到结果表:

60cfd7c52bcc41926f22ec92df08d022.png

显然方法二比一更简洁高效

未完待续....!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值