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;
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 customerid
from orders
where 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);
#输出结果为 7
mysql> 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
待更新。。。