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)并无匹配对应记录。

mysql查询一个字段关键字另一个表的数据 mysql 查询关键字_数据库

内连接

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

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
键字

例子

mysql查询一个字段关键字另一个表的数据 mysql 查询关键字_mysql_02

# 因为是判断不存在,故可以使用 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

例子

mysql查询一个字段关键字另一个表的数据 mysql 查询关键字_字段_03

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

待更新。。。