iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MYSQL函数的使用梳理
  • 333
分享到

MYSQL函数的使用梳理

2024-04-02 19:04:59 333人浏览 薄情痞子
摘要

目录Mysql函数1:聚合函数2:数学函数2:字符串函数3:日期函数4:控制流函数5:窗口函数5.1 序号函数5.2 分布函数5.3 前后函数5.4 头尾函数5.5 其他函数5.6

mysql函数

1:聚合函数

聚合函数主要由:count,sum,min,max,avg,group_count()

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

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

说明:

      1:使用distinct可以排除重复值.
      2:如果需要对结果值进行排序,可以使用order by 子句.
      3:separator是一个字符串值,默认为逗号.

2:数学函数

1:ABS(x) 返回x的绝对值
2:CEIL(x)返回大于等于x的最小整数(向上取整)
3:FLOOR(x) 返回小于等于x的最大整数(向下取整)
4:GREATEST(expr1,expr2...)返回列表中的最大值
5:LEAST(expr1,expr2.....)返回列表的最小值
6:MAX(x) 返回字段x的最大值
7:MIN(x) 返回字段x的最小值
8:MOD(x,y) 返回x除以y以后的余数
9:PI()返回圆周率(3.141593)
10:POW(x,y) 返回x的y次方
11:RAND() 返回0到1的随机数
12:ROUND(x) 返回离x最近的整数(遵循四舍五入)
13:ROUND(x,y) 返回指定位数的小数(遵循四舍五入)
14:TRUNCATE(x,y) 返回数值x保留到小数点后y位的值,(与ROUND最大的去区别是不会进行四舍五入)

2:字符串函数

1:char_length(s) 返回字符串s的字符数
2:character_length 返回字符串s的字符数
3:concat(s1,s2,s3) 字符串s1,s2等多个字符串合并为一个字符串
4:concat_ws(x,s1,s2..) 同concat(s1,s2,s3)函数,但是每个字符串之间要加上x,x可以是分隔符
5:field(s,s1,s2) 返回第一个字符串s在字符串列表(s1,s2..)中的位置
6:length() 返回的是字节数 mysql中utf-8的编码 一个中文汉字是三个字节
7:ltrim(s) 去掉字符串s开始处的空格 去除左边的空格  rtrim()去除右边的空格 trim()去除两边的空格
8:mid(s,n,len) 从字符串s的n位置截取长度为len的子字符串同substring(s,n,len)
9:position(s1,in,s) 从字符串s中获取s1的开始位置
10:replcae(s,s1,s2) 将字符串s2替代字符串s中的字符串s1
11:reverse(s) 将字符串s的顺序反过来
12:right(s,n)返回字符串s的后n个字符(从右取n个字符)
13:strcmp(s1,s2) 比较字符串s1和s2,如果s1与s2相等返回0,如果s1>s2返回1 如果s1小于s2返回-1
14:substr(s,start,length) 从字符串s的start位置截取长度为length的子字符串
15:ucase(s) upper(s)将字符串转换为大写
16:lcase(s) lower(s) 将字符串转换为小写

3:日期函数

1:unix_timestamp() 返回1970-01-01 00:00:00 到当前毫秒值
2:unix_timestamp(date_string) 将指定日期转换为毫秒值时间戳
3:from_unixtime(bigint unixtime,string-fORMat) 将毫秒值时间戳转为指定格式日期
4:curdate() 返回当前日期
5:current_date() 返回当前日期
6:current_timestamp() 返回当前日期和时间
7:datediff(d1,d2) 计算日期d1>d2之间间隔的天数  eg:datediff('2022-01-01','2022-02-01')
8:currtime() 返回当前时间 
9:date_format(d,f) 按照表达式f的要求显示日期d

4:控制流函数

1:if(expr,v1,v2) 如果表达式expr成立,返回结果v1,否则返回结果v2
2:ifnull(v1,v2) 如果v1的值为null则返回v1,否则返回v2 
3:isnull(expression) 判断表达式是否为null 
4:nullif(expr1,expr2)  比较两个字符串 如果字符串expr1和expr2相等 返回null 否则返回expr1
5:case expression when condition1 then result1  when condition2 then result2 else result end 表示case函数开始,end表示函数结束,如果condition1成立则返回result1,如果condition2成立则返回result2,当全部不成立则返回result,而当有一个成立之后,后面的就不执行了.

5:窗口函数

mysql8.0新增的窗口函数又称为开窗函数,非聚合窗口函数是相对于聚合函数来说,聚合函数是对一组数据计算后返回单个值(即分组),非聚合函数一次只会处理一行数据,窗口聚合函数在行记录上计算某个字段的结果时,可将窗口范围内的数据输入到聚合函数中,并不改变行数

5.1 序号函数

可以实现分组排序,并添加序号

1: row_number()
2: rank()
3: dense_rank() 

写法:select id,...,dense_rank() over(partition by dname order by salary desc) as rn from employee;

注意: 不加 partition by 表示全局排序

5.2 分布函数

1: percent_rank()
  用途:每行按照公式(rank-1)/(row-1)进行计算.其中rank为rank()函数产生的序号,row为当前窗口的记录总行数
2: cume_dist()
  用途:分组内小于,等于当前rank值的行数/分组内总行数
  应用场景:查询小于等于当前薪资的比例

写法:select dname,ename,salary,cume_dist() over(order by salary) as rn1,
cume_dist() over(partition by dname order by salary) as rn2 from employe;

5.3 前后函数

1: lag(expr,n)
2: lead(expr,n)

用途:返回位于当前行的前n行(lag(exor,n))或后n行(lead(expr,n))的expr的值

应用场景:查询前1名同学的成绩和当前同学成绩的差值 (当前行内可以有个上一行数据的某一字段值)

5.4 头尾函数

1: first_value(expr)
2: last_value(expr)

用途:返回第一个(first_value(expr))或者最后一个(last_value(expr)) expr的值
应用场景:截止到当前,按照日期排序查询第1个入职和最后一个入职员工的薪资

5.5 其他函数

1: nth_value(expr,n)
2: ntile(n)

用途:返回窗口中第n个expr的值,expr可以是表达式,也可以是列名
应用场景:截止到当前薪资,显示每个员工的薪资中排名第二或者第三的薪资

5.6 开窗聚合函数

1: sum()
2: avg()
3: min()
4: max()

写法:select id,...,sum(salary) over(partition by dname order by hiredate desc) as rn from employee;

每一行rn的数据是当期行和之前每一行的salary之和
如果没有order by排序语句,默认把分组内的所有数据进行sum操作

到此这篇关于MYSQL函数的使用梳理的文章就介绍到这了,更多相关MYSQL函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: MYSQL函数的使用梳理

本文链接: https://www.lsjlt.com/news/147919.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MYSQL函数的使用梳理
    目录MYSQL函数1:聚合函数2:数学函数2:字符串函数3:日期函数4:控制流函数5:窗口函数5.1 序号函数5.2 分布函数5.3 前后函数5.4 头尾函数5.5 其他函数5.6 ...
    99+
    2024-04-02
  • MySQL特殊函数使用技巧梳理
    目录1. group_concat2. char_length3.locate4.replace5.now6.insert into … select7.in...
    99+
    2023-05-20
    mysql特殊函数 mysql特有函数 mysql特有语句
  • mysql常用函数与视图索引全面梳理
    目录常用函数几种函数类型1、日期函数2、字符串函数3、数字函数4、聚合函数合并视图索引视图概念及特点视图作用基本语法索引概念优缺点分类索引维护常见的错误代码常用函数 函数的概念及特点: 与Java,js中的函数概念一致 ...
    99+
    2024-04-02
  • Java 函数式编程梳理
    目录一、Lambda表达式 1.1 函数式编程思想概述1.2 体验Lambda表达式1.3 Lambda表达式的标准格式1.4 Lambda表达式的练习1.5 Lambda...
    99+
    2024-04-02
  • C语言内存操作函数使用示例梳理讲解
    目录一、memcpy()函数原型参数说明模拟算法使用示例二、memmove()函数原型参数说明模拟算法使用示例三、memset()函数原型参数说明使用说明使用示例四、memcmp()...
    99+
    2024-04-02
  • SQLServer常见数学函数梳理总结
    目录SQLServer常见的数学函数1.绝对值函数ABS(x)和返回圆周率的函数PI()2.平方根函数SQRT(x)3.获取随机数的函数RAND()和RAND(x)4.四舍五入函数R...
    99+
    2022-11-13
    SQLServer数学函数 SQLServer函数
  • C++分析构造函数与析造函数的特点梳理
    目录构造函数的调用构造函数的分类及调用拷贝构造的调用时机深拷贝与浅拷贝构造函数的调用 默认情况下编译器至少给一个类添加3个函数 1.默认构造函数(无参,函数体实现)--完成对象的初始...
    99+
    2024-04-02
  • MySQL数据处理梳理讲解增删改的操作
    目录一、插入数据VALUES的方式添加为表的所有字段按默认顺序插入数据为表的指定字段插入数据同时插入多条记录将查询结果插入到表中二、更改数据(更新)三、删除数据一、插入数据 VALU...
    99+
    2024-04-02
  • MySQL过滤数据操作方法梳理
    目录前言1. where 字句的使用2. where 字句操作符2.1 检查单个值2.2 不匹配检查2.3 范围值检查2.4 空值检查3. 扩展3.1 SQL过滤与应用过滤3.2 引号的使用3.3 N...
    99+
    2024-04-02
  • 关于ES6中的箭头函数超详细梳理
    目录一、箭头函数的介绍1.1 什么是箭头函数1.2 基本语法1.3 箭头函数的参数1.4 箭头函数的函数体二、箭头函数的this指向规则三、箭头函数的arguments规则3.1 箭...
    99+
    2022-11-13
    es6箭头函数详解 es6箭头函数作用 es6 箭头
  • MySQL检索数据操作方法梳理
    目录前言:1. select语句-用于检索所有列2. 注释的使用前言: 本实验中所用数据库创建SQL代码以及插入数据SQL代码链接: 链接: https://pan.bai...
    99+
    2022-11-13
    MySQL检索数据 MySQL数据检索
  • MySQL函数Locate的使用
    Locate函数主要的作用是判断一个字符串是否包含另一个字符串,如 Locate(str,sub) > 0,表示sub字符串包含str字符串; Locate(str,sub) = 0,表示sub字符串不包含str字符串。 该函数常常与 组件...
    99+
    2023-09-01
    java mybatis
  • MySql恢复数据方法梳理讲解
    目录一、前言二、步骤三、其它笔记一、前言 mysql具有binlog功能,可以记录对表进行过的操作、执行过的sql语句; 以下主要是总结下binlog的开启方法、使用方法等; 如果误...
    99+
    2022-11-13
    MySql 恢复数据 MySql 数据恢复
  • Vue Element plus使用方法梳理
    目录说明一、组件属性的使用二、组件内部事件的使用三、组件插槽的使用四、组件外部方法的使用1、使用外部方法是要调用标签的$refs2、使用方法说明 本教程适用于Element-plus...
    99+
    2022-12-23
    Element plus使用方法 Vue Element plus
  • MySQL函数的使用示例
    小编给大家分享一下MySQL函数的使用示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!案例:使用各种函数操作数据,掌握各种函数...
    99+
    2024-04-02
  • Java抽象类和接口使用梳理
    目录抽象类抽象方法抽象类三大原则接口接口使用原则JDK两大内置接口java.lang.Comparable 比较接口java.lang.Cloneable 克隆接口对象的深浅拷贝抽象...
    99+
    2024-04-02
  • Java超全面梳理内部类的使用
    目录一、内部类1.内部类的概念2.内部类的定义3.内部类与外部类的访问规则4.内部类的注意事项二、匿名内部类一、内部类 1.内部类的概念 内部类是定义在类中的类。 内部类把逻辑上相关...
    99+
    2024-04-02
  • Mybatis的where标签使用总结梳理
    目录背景原始的手动拼接Mybatis where标签的使用进阶:自定义trim标签where语句的坑小结背景 在上篇文章,我们系统地学习了where 1...
    99+
    2024-04-02
  • python常用数据结构字典梳理
    目录dict字典字典定义与使用字典使用:创建字典使用:访问元素字典使用:操作元素字典使用:嵌套字典字典常用方法values()items()values()get()update()...
    99+
    2024-04-02
  • MySQL排序检索数据操作方法梳理
    目录前言1. 排序数据2. 按多个列排序3. 按列位置排序4. 指定排序方式(升序或者降序)5. 扩展—文本性数据如何排序前言 本实验中所用数据库创建SQL语句以及插入数据到数据库中的SQL语句链接: 链接:...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作