当前位置: 首页 > article >正文

mysql查询关键词总结

limit

limit一般用于分页

# 取前三条数据
select * from user limit 3
# 取第2,3,4条数据
select * from user limit 1,3

offset

当limit和offset组合使用的时候,limit后面只能有一个参数,表示要取的数量,offset表示要跳过的数量。

# 取第2,3,4条数据
select * from user limit 3 offset 1

distinct

使用MySQL DISTINCT子句来消除结果集中的重复行。

# 去除重复工资
select distinct salary from employee

count()函数

COUNT() 是一个聚合函数,返回指定匹配条件的行数。开发中常用来统计表中数据,全部数据,不为NULL数据,或者去重数据。

# 统计所有的记录(包括NULL)。
select count(*) from user;# 统计不为NULL 的记录。
select count(1) from user;# COUNT(字段):统计该"字段"不为NULL 的记录,注意是null不是空''字符串
select count(name) from user;# COUNT(DISTINCT 字段):统计该"字段"去重且不为NULL 的记录。
select count(distinct name) from user;

in

mysql中in常用于where表达式中,其作用是查询某个范围内的数据。

# 查询id是20或者是30
# 等同于select * from student s where s.id = 20 or s.id = 30;
select * from student s where s.id in (20,30);# 查询每个班级中分数最高的学生的所有数据
select * from student s where (s.class , s.score) in (select class , max(score) from student group by class)

join

INNER JOIN(内连接,或等值连接):取得两个表中存在连接匹配关系的记录。
LEFT JOIN(左连接):取得左表(table1)完全记录,即是右表(table2)并无对应匹配记录。
RIGHT JOIN(右连接):与 LEFT JOIN 相反,取得右表(table2)完全记录,即是左表(table1)并无匹配对应记录。

请添加图片描述

内连接

作用:查询两张表共有的部分

SELECT * from employee e INNER JOIN department d on e.dep_id = d.id;

left join

作用:左连接从左表(A)产生一套完整的记录,与匹配的记录(右表(B)) .如果没有匹配,右侧将包含null。

select * from A left join B on A.name = B.name;
# 如果想只从左表(A)中产生一套记录,但不包含右表(B)的记录,可以通过设置where语句来执行,如下:
select * from A left join B on A.name=B.name where A.id is null or B.id is null;

join具体用法

having

mysql中,当我们用到聚合函数,如sum,count后,又需要筛选条件时,having就派上用场了,因为WHERE是在聚合前筛选记录的,having和group by是组合着用的

注意 having后的判断字段必须是聚合函数返回的结果

# 显示每个地区的总人口数和总面积.
# 先以region把返回记录分成多个组,这就是GROUP BY的字面含义。分完组后,然后用聚合函数对每组中
的不同字段(一或多条记录)作运算。
SELECT region, SUM(population), SUM(area) 
FROM bbc 
GROUP BY region
# 显示每个地区的总人口数和总面积.仅显示那些面积超过1000000的地区。
SELECT region, SUM(population), SUM(area)
FROM bbc
GROUP BY region
HAVING SUM(area)>1000000

EXISTS

判断数据是否存在,相反如果想判断数据是否不存在可以使用NOT EXISTS
键字

例子

请添加图片描述

# 因为是判断不存在,故可以使用 not exists关键词
select Name as Customers
from customers c
where not exists (select customeridfrom orderswhere customerid = c.id
)

union

union:会对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序。
union all:对两个结果集进行并集操作,包括重复行,不会对结果进行排序。

case

类似于switch case

例子

请添加图片描述

select case when age < 25 or age is null then '25岁以下'when age >= 25 then '25岁及以上'end age_cut, count(*) as number
from user_profile
group by age_cut

日期函数

DAYOFWEEK(date)

返回日期date的星期索引(1=星期天,2=星期一, ……7=星期六)。这些索引值对应于ODBC标准。

select DAYOFWEEK('1998-02-03')
#输出结果为 3

WEEKDAY(date)

返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。

mysql> select WEEKDAY('1997-10-04 22:23:00');
#输出结果为 5

DAYOFMONTH(date)

返回date的月份中日期,在1到31范围内。

mysql> select DAYOFMONTH('1998-02-03');
#输出结果为 3

DAYOFYEAR(date)

返回date在一年中的日数, 在1到366范围内。

mysql> select DAYOFYEAR('1998-02-03');
#输出结果为 34

MONTH(date)

返回date的月份,范围1到12。

mysql> select MONTH('1998-02-03');
#输出结果为 2

DAYNAME(date)

返回date的星期名字。

mysql> select DAYNAME("1998-02-05");
#输出结果为 'Thursday'

MONTHNAME(date)

返回date的月份名字。

mysql> select MONTHNAME("1998-02-05");
#输出结果为'February'

QUARTER(date)

返回date一年中的季度,范围1到4。

mysql> select QUARTER('98-04-01');
#输出结果为 2

WEEK(date)

对于星期天是一周的第一天的地方,有一个单个参数,返回date的周数,范围在0到52。

mysql> select WEEK('1998-02-20');
#输出结果为 7

WEEK(date, first)

2个参数形式WEEK()允许你指定星期是否开始于星期天或星期一。
如果第二个参数是0,星期从星期天开始,
如果第二个参数是1,从星期一开始。

mysql> select WEEK('1998-02-20',0);
#输出结果为 7mysql> select WEEK('1998-02-20',1);
#输出结果为 8

YEAR(date)

返回date的年份,范围在1000到9999。

mysql> select YEAR('98-02-03');
#输出结果为 1998

HOUR(time)

返回time的小时,范围是0到23。

mysql> select HOUR('10:05:03');
#输出结果为 10

MINUTE(time)

返回time的分钟,范围是0到59。

mysql> select MINUTE('98-02-03 10:05:03');
#输出结果为 5

SECOND(time)

回来time的秒数,范围是0到59。

mysql> select SECOND('10:05:03');
#输出结果为 3

PERIOD_ADD(P,N)

增加N个月到阶段P(以格式YYMM或YYYYMM)。以格式YYYYMM返回值。注意阶段参数P不是日期值。

mysql> select PERIOD_ADD(9801,2);
#输出结果为 199803

PERIOD_DIFF(P1,P2)

返回在时期P1和P2之间月数,P1和P2应该以格式YYMM或YYYYMM。注意,时期参数P1和P2不是日期值。

mysql> select PERIOD_DIFF(9802,199703);
#输出结果为 11

between

# 在10~20之间
between 10 and 20# 不在10~20之间
not between 10 and 20

substring_index

substring_index(str, delim, count)
str要处理的字符串
delim分隔符
count计数

# eg
str=www.baidu.com
substring_index(str,'.', 1)
# 结果为:www
substring_index(str,'.', 2)
#结果为:www.baidu
substring_index(str,'.', -2)
#结果为:baidu.com
substring_index(substring_index(str,'.', -2),'.', 1)
#结果为:baidu

待更新。。。

http://www.lryc.cn/news/2421187.html

相关文章:

  • 6.2路由器与交换机的作用与特点
  • VMware View 5.0 – 远程图形工作站配置篇
  • 用计算机测试生日,超准生日爱情配对测试
  • 最全、最详细的MySQL常用命令(MySQL)
  • 干式真空泵原理_如何安装干式墙锚在墙壁上悬挂重物
  • 【转】2009年值得去关注的15个国内web2.0网站
  • 赢销侠的秘密武器:如何通过创新思维提升业绩
  • [喵咪开源软件推荐(5)]开源DNS服务-bind
  • Linux - tftp
  • 【Windows源码分析】(一)初始化内核与执行体子系统
  • win10系统任务栏卡死怎么办(三种方式)
  • 去除织梦底部版权信息Power by DedeCms
  • Proteus中常用元器件快速查找教程
  • JavaScript深入浅出(进阶)
  • python shell手机版_PythonScriptShell/Python for s60 3rd v1.4.5
  • 【Oracle软件下载大全】Oracle 9i、10g、11g软件下载地址大全—最新下载!
  • MFC绘制圆形进度条(附完整源码)
  • firefox android 阅读模式,何必羡慕Safari 5?火狐浏览器也有“阅读模式”
  • 数据补全与数据挖掘: 如何提高挖掘效率
  • 夹缝求生存,勤者存。
  • C++ 实现 ping 功能 域名(URL)解析实际 IP地址
  • Password Guessing Using Random Forest使用随机森林猜密码
  • Google Analytics(Google分析)与雅虎统计的对比
  • 5款超级种子下载神器合集
  • 达梦数据库一些疑难杂症的解决
  • Launcher介绍总结
  • 递归与循环的优缺点
  • 电脑计算机磁盘打不开6,可移动磁盘打不开怎么解决 6个步骤轻松搞定
  • setTimeout 和 setInterval 的区别.
  • 太强了哎 突然发现一个网安神器~