首页 > 数据库 >第十篇:MySQL内置函数(字符串函数|数值函数|日期函数|流程函数)

第十篇:MySQL内置函数(字符串函数|数值函数|日期函数|流程函数)

时间:2024-03-24 21:34:07浏览次数:29  
标签:演示 函数 第十篇 实例 str MySQL 字符串 描述

函数就是一段写好的、具有特定功能的代码,可以被另一段程序直接调用,只要拥有编程基础。想必对函数并不陌生

本篇将系统性地记录MySQL中常用的内置函数,主要分为这四大类,

  • 字符串函数
  • 数值函数
  • 日期函数
  • 流程函数


一,字符串函数

(一)concat(S1, S2,...Sn) <-拼接

作用描述

将传入的多个子字符串拼接成一个母字符串后,返回母串

实例演示

如下图,使用concat()函数对3个子串进行拼接后使用【select】关键字输出的结果是3个子串拼接成的母串

(二)lower(str) <-小写字母化

作用描述

将字符串str中的所有字母全部小写化,非字母字符则不做处理

实例演示

如下图,使用lower()函数对字符串【"@#MySQL!%"】小写字母化后,使用【select】关键字输出,结果显示大写字母均变为小写字母

(三)upper(str) <-大写字母化

作用描述

将字符串str中的所有字母全部大写化,非字母字符则不做处理

实例演示

如下图,使用upper()函数对字符串【"@#MySQL!%"】大写字母化后,使用【select】关键字输出,结果显示小写字母均变为大写字母

(四)lpad(str, n, pad) <-左填充

作用描述

使用pad字符从左边去填充字符串str,使其长度为n

实例演示

例如需要在最大长度为5的id前面补前导0,长度不足5就补0,满足长度为5就不补

(五)rpad(str, n, pad) <-右填充

作用描述

使用pad字符从右边去填充字符串str,直至填充后的字符串长度为n

实例演示

和【一.(四)】的lpad()函数同理,不多做说明

(六)trim(str) <-去除头尾空格

作用描述

将字符串str头尾(即左右两边)的空格全部去除,对于字符中间的空格则不做处理

实例演示

(七)substring(str, start, len) <-截取字符串

作用描述

从索引start开始截取字符串str,直至截取出的字符串满足长度为len

注意:

  • 不同于一般编程语言的字符串索引起始为0,该函数默认字符串的索引起始为1(即第一个字符的索引/下标被视为1)
  • 使用该函数截取字符串时,截取出的子串长度小于等于str

实例演示


 二,数值函数

(一)ceil(x) <-向上取整

作用描述

对浮点数x向上取整,

实例演示

(二)floor(x) <-向下取整

作用描述

对浮点数x向下取整

实例演示

(三)mod(x, y) <-取模(求余数)

作用描述

计算x除以y的余数,即求x%y

实例演示

(四)rand() <-获取0~1随机数

作用描述

产生0到1的随机浮点数

实例演示

(五)round(x, y) <-四舍五入x保留y位小数

作用描述

对x四舍五入并保留y位小数

实例演示


 三,日期函数

(一)curdate() <-返回当前年月日

作用描述

返回当前日期,结果由【yyyy-mm-dd】格式的年月日组成

实例演示

(二)curtime() <-返回当前时分秒

作用描述

返回当前时刻,结果由【hh:mm:ss】格式的时分秒组成

实例演示

(三)now() <-返回当前年月日和时分秒

作用描述

返回当前日期和时刻,结果由【yyyy-mm-dd hh:mm:ss】格式的年月日时分秒组成

实例演示

(四)year(date) <-获取指定date的年份

作用描述

从格式为【yyyy分隔符mm分隔符dd】的字符串date中获取年份

  • 此处的date字符串中,年月日的分隔符可以是【减号(-)or冒号(:)or左斜杠(/)or竖线(|)or加减乘除模(+-*/%)】等多种符号类字符,但不能是右斜杠(\)
  • 该字符串允许在末尾加上时分秒
  • 给出的年月日需要在合法日期中,例如不存在13月份,32号等

实例演示

(五)month(date) <-获取指定date的月份

作用描述

作用是获取月份,规则和【三.(四)】的year(date)函数一致

实例演示

(六)day(date) <-获取指定date的日期

作用描述

作用是获取月份,规则和【三.(四)】的year(date)函数一致

实例演示

(七)date_add(date, interval expr type) <-返回当前日期加上expr后的时间

作用描述

date是从格式为【yyyy分隔符mm分隔符dd】的字符串,interval是固定的参数,expr是间隔数值,type是类型,有year,month,day分别代表年月日,该函数会计算传入的时间加上间隔expr个type之后的时间

  • 此处的date字符串中,年月日的分隔符可以是【减号(-)or冒号(:)or左斜杠(/)or竖线(|)or加减乘除模(+-*/%)】等多种符号类字符,但不能是右斜杠(\)
  • 该字符串允许在末尾加上时分秒
  • 给出的年月日需要在合法日期中,例如不存在13月份,32号等

实例演示

(八)datediff(date1, date2) <-返回时间段之间的天数

作用描述

date1和date2是从格式为【yyyy分隔符mm分隔符dd】的字符串,该函数将计算date1减去date2的天数(即从date2到date1需要过多少天)

  • 此处的date字符串中,年月日的分隔符可以是【减号(-)or冒号(:)or左斜杠(/)or竖线(|)or加减乘除模(+-*/%)】等多种符号类字符,但不能是右斜杠(\)
  • 该字符串允许在末尾加上时分秒
  • 给出的年月日需要在合法日期中,例如不存在13月份,32号等

实例演示


四,流程(条件判断)函数

(一)if(value, t, f) <-判断value的真假

作用描述

如果value为true,返回t,否则返回f

实例演示

(二)ifnull(value1, value2) <-判断null值

作用描述

如果value1为null,返回value2,否则返回value1,注意,这里的null指的是空值,类似空字符("")和整数0等并不属于空值,易混淆

实例演示

(三) case expr when val1 then res1...else default end

作用描述

如果expr的值等于val1,返回res1,...否则返回default

(有点难描述,其实就相当于C/C++/Java里面的if...else if...else if...else)

实例演示

(不便直接演示所以直接搬视频截图了,理解记忆就好!)

标签:演示,函数,第十篇,实例,str,MySQL,字符串,描述
From: https://blog.csdn.net/liKeQing1027520/article/details/136385912

相关文章

  • 内存函数撼大树
    目录前言一、memcpy二、memmove三、memset四、memcmp前言本章我们学习一下内存函数,我们将从memcpy、memmove、memset、memcmp这几个内存函数的用途和使用方法方面为大家进行讲解,话不多说我们开始一、memcpyvoid*memcpy(void*destination,constvoid*sour......
  • 向线程函数传递参数
    向std::thread构造函数中的可调用对象,或函数传递一个参数很简单。需要注意的是,默认参数要拷贝到线程独立内存中,即使参数是引用的形式,也可以在新线程中进行访问 。voidf(inti,std::stringconst&s);std::threadt(f,3,"hello");代码创建了一个调用f(3,"hello")的......
  • 第9讲:函数递归
    第9讲:函数递归1.递归是什么?1.1递归的思想:1.2递归的限制条件2.递归举例2.1举例1:求n的阶乘2.1.1分析和代码实现2.1.2画图推演2.2举例2:2.2.1分析和代码实现2.2.2画图推演3.递归与迭代1.递归是什么?递归是学习C语言函数绕不开的⼀个话题,那什么是递归呢?递......
  • Scala函数练习题
    1、定义一个高阶函数,按照指定的规则对集合里面的每个元素进行操作比如:Array(“hh”,“red”,“java”,“hadoop”)规则:对集合中每个元素进行操作,得到集合每个元素的长度objecttest{defmain(args:Array[String]):Unit={vallist=Array("hh","red","ja......
  • 详解rtklib中main函数如何配置文件(下)
    目录一、main函数流程总结二、分析识别-k后如何配置三、最后传参的数据文件处理方式 一、main函数流程总结详解rtklib中main函数如何配置文件(上)-CSDN博客在这片文章中讲解了rtklib中main函数的整个流程。(1)通过两种方法给main函数传递参数,并放在argv这个指针数组......
  • 【附源码】JAVA计算机毕业设计音乐豆瓣(springboot+mysql+开题+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着信息技术的迅猛发展,音乐作为人们日常生活中不可或缺的一部分,其获取与分享方式也在不断地变革。传统的音乐获取途径,如购买唱片或到实体音乐店挑选......
  • 初识C++(二)引用,内联函数,auto
    目录1.引用的概念与用法:1.1引用特性:1.2使用场景    1.2.1做参数1.3传值、传引用效率比较1.4引用做返回值1.5引用和指针的对比2.内联函数3.auto关键字4.基于范围的for循环(C++11)5.指针空值nullptr(C++11)1.引用的概念与用法:    引用是一个重要的......
  • 直方图和密度函数——Python实现
    概率密度函数是概率论核心概念之一,用于描述连续型随机变量所服从的概率分布,是概率计算的通用表达。研究一个随机变量,不只是要看它能取哪些值,更重要的是它取各种值的概率如何!在实际使用时对应离散化后的频率。也可以这样理解,概率密度函数是数学通用表达的频率,而统计学中的频率是将......
  • docker安装mysql
    1.创建本地文件夹mkdir-p/docker/mysql8/confmkdir-p/docker/mysql8/datamkdir-p/docker/mysql8/log2.新建配置文件在conf文件夹中创建文件:mysql.conf文件内容:[mysqld]init-connect="SETcollation_connection=utf8mb4_0900_ai_ci"init_connect="SETNAMESutf8......
  • 10_FreeRTOS任务相关API函数
    FreeRTOS任务相关API函数FreeRTOS任务相关API函数介绍UBaseType_tuxTaskPriorityGet(constTaskHandle_txTask)voidvTaskPrioritySet(TaskHandle_txTask,UBaseType_tuxNewPriority)UBaseType_tuxTaskGetNumberOfTasks(void)uxTaskGetSystemStatevTaskGe......