mysql一些常用函数

mysql一些常用函数_第1张图片

 group_concat()函数首先根据group by指定的列进行分组,并且用分隔符分隔,将同一个分组中的值连接起来,返回一个字符串结果。

group_concat([distinct] 字段名 [order by 排序字段 asc/desc] [separator '分隔符'])

-- 指定排序方式和分隔符 
select department,group_concat(emp_name order by salary desc separator ';' ) from emp group by department;

mysql一些常用函数_第2张图片

 mysql一些常用函数_第3张图片

 mysql一些常用函数_第4张图片

mysql一些常用函数_第5张图片

mysql一些常用函数_第6张图片

 mysql一些常用函数_第7张图片

mysql一些常用函数_第8张图片

mysql一些常用函数_第9张图片

 mysql一些常用函数_第10张图片

-- 序号函数有三个:ROW_NUMBER()、RANK()、DENSE_RANK(),可以用来实现分组排序,并添加序号。

-- 格式
row_number()|rank()|dense_rank() over (

  partition by ...

  order by ...

)

 
操作
-- 对每个部门的员工按照薪资排序,并给出排名
select
    dname,
    ename,
    salary,
    row_number() over(partition by dname order by salary desc) as rn
from employee;

mysql一些常用函数_第11张图片

-- 对每个部门的员工按照薪资排序,并给出排名 rank
select 
dname,
ename,
salary,
rank() over(partition by dname order by salary desc) as rn 
from employee;

mysql一些常用函数_第12张图片

-- 对每个部门的员工按照薪资排序,并给出排名 dense-rank
select 
dname,
ename,
salary,
dense_rank() over(partition by dname order by salary desc) as rn 
from employee;

mysql一些常用函数_第13张图片

 mysql一些常用函数_第14张图片

 mysql一些常用函数_第15张图片

mysql一些常用函数_第16张图片

你可能感兴趣的:(mysql,数据库,sql)