MySQL自学笔记2--select的5个子句

MySQL自学笔记

使用的MySQL自带命令客户端,其中具体的操作是在自建的数据库下room303表中进行的,表中的列有:id、name、age、email、tel、salary、riqi、class。元组为自己随便添加的一些成员=.=!

select子句

五种,包括:where、group by、having、order by、limit

where:条件查询

where可以用在各种条件查询的场合,有如下一些常用的运算符
* < 小于
* > 大于
* MySQL
select * from room303
where age > 22;

* != 不等于(用<>也可以表示不等于)
* MySQL
select * from room303
where age <> 23;

* <= 小于等于
* >= 大于等于
* MySQL
select name, age, riqi from room303
where age >= 21;

* in(值1, 值2, 值3, …) 表示在集合内的值都可以
* MySQL
select * from room303
where age in(20,23);

* between A1 and A2 表示介于A1、A2之间的值都可以,包括A1、A2
* MySQL
select * from room303
where age between 21 and 23;

* MySQL
select * from room303
where age not between 21 and 23;

* not(或者!) 表示逻辑非、or(或者||) 表示逻辑或、and(或者&&) 表示逻辑与
* MySQL
select * from room303
where age <=22 and salary between 1000 and 1800;

group by:分组查询

group by通常用在统计场合,一般用到如下的函数有这几个:max、min、sum、avg、count
* max:求最大值
* MySQl
select class, min(salary) from room303 group by class;

* min:求最小值
* sum:求和
* avg:求平均
* count:求总行数
* MySQL
select class, count(age) from room303 group by class;

MySQL
select class, count(*) from room303 group by class;

* 上面两个获得的结果是一样的,因为count求的是总行数
* 这里得注意的一点是在group by分组之后,max、min等想要找到的该列是正确的,但是对于获得的数据其他列中的值是group by分组后碰到的第一条记录!如果想要获得真正的结果,可以使用嵌套或者联合进行查询获得!

having:与where类似用于条件筛选

having后面接的语句与where类似,where后面的表达式怎么写,having就怎么写,但是两者之间有一个很重要的区别就是:
* where是针对表中的列进行筛选,查询数据
* having是针对查询结果中的列进行筛选,查询已经得到的结果中的数据
* 简单的说:where对表起作用,having对结果进行筛选
* MySQL
select * from room303
where age >=22
having salary < 1900;

order by:排序

orde by可以用于各种排序场合,可以根据字段来进行升序(asc)或者降序(desc)的排列,默认是升序进行排列。排列可以按多字段来进行排列。
* 多字段排序
MySQL
order by 列1 [desc/asc],列2 [desc/asc],...

MySQL
select * from room303 order by age desc, salary asc;

limit:限制

limit放在语句的最后,用来限制条目用的,其格式如下:

limit [offset] [N]
  • offset是偏移量(不写的话默认值为0),N是取出的条目数
    *MySQL
    select * from room303 limit 1,2;

select五个子句的顺序问题

这5个select子句在SQL语句中是有顺序要求的,具体顺序为:
wheregroup byhavingorder bylimit

转载于:https://www.cnblogs.com/NickBryant/p/6350273.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值