11_常用函数

news2025/4/11 15:51:49

文章目录

    • 一、概述
    • 二、字符函数
      • 2.1、获取字符串所占字节数
      • 2.2、获取字符个数
      • 2.3、拼接字符串
      • 2.4、大小写转换
      • 2.5、获取子串
      • 2.6、获取子串第一次出现的索引
      • 2.7、去除字符串前后子字符串
        • 2.7.1、去掉左侧空格
        • 2.7.2、去掉右侧空格
      • 2.8、左右填充
      • 2.9、字符串替换
    • 三、数学函数
      • 3.1、四舍五入
      • 3.2、向上取整
      • 3.3、向下取整
      • 3.4、取模
      • 3.5、截断
      • 3.6、随机数
    • 四、日期函数
      • 4.1、当前日期和时间
      • 4.2、获取年月日时分秒
      • 4.3、日期转换
    • 五、其他函数

一、概述

功能:类似Java中的方法;

优势:提高重用性和隐藏实现细节;

调用:select 函数名(参数列表)

分类:

  • 字符函数
  • 数学函数
  • 日期函数
  • 聚合函数(之前已经学习过)
  • 其他函数

二、字符函数

2.1、获取字符串所占字节数

语法:length('字符串')

注意:在utf-8编码下英文字符占一个字节,中文占三个字节。

# 获取“你好hello”字符串所占字节数
select length('你好hello');
# 查询员工姓名及姓名所占字节数
select ename, length(ename) from emp;

2.2、获取字符个数

语法:char_length('字符串')

# 获取“你好hello”字符个数
select char_length('你好hello');
# 获取员工姓名及姓名所占字符个数
select ename, char_length(ename) from emp;

2.3、拼接字符串

语法:concat('字符串1','字符串2','字符串3',...)

select concat('abc', '_', 'def');
# 查询员工及其上级的姓名,并使用"_"分隔
select concat(e.ename, '_', m.ename) from emp e, emp m where e.mgr=m.empno;

2.4、大小写转换

语法:

  • 变大写:upper('字符串')
  • 变小写:lower('字符串')
select upper('abc');
select lower('AB');
# 查询所有员工的姓名,将其姓名转换为大写
select upper(ename) from emp;
# 查询所有员工的姓名,将其姓名转换为小写
select lower(ename) from emp;

2.5、获取子串

语法:

  • substr('字符串', 起始位置),从起始位置开始到结尾
  • substr('字符串', 起始位置, 长度),从起始位置开始,返回特定长度的字符串

注意:字符串的第一个字符的下标为1

# 返回“bcd”
select substr('abcd', 2);
# 返回“ello”
select substr('hello world', 2, 4);

2.6、获取子串第一次出现的索引

语法:instr('字符串','子字符串')

# 返回7
select instr('hello world', 'world');

2.7、去除字符串前后子字符串

语法:trim([{BOTH | LEADING | TRAILING} [remstr] FROM] str)

# 去除开头的'a'
select trim(leading 'a' from 'aaaaahelloaaa');
# 去除末尾的'a'
select trim(trailing 'a' from 'aaaaahelloaaa');
# 去掉前后的'a'
select trim(both 'a' from 'aaaaahelloaaa');
select trim('a' from 'aaaaahelloaaa');
# 去掉两侧空格
select trim('        mysql        ');
2.7.1、去掉左侧空格

语法:ltrim('字符串')

select ltrim('   aaaa ');
2.7.2、去掉右侧空格

语法:rtrim('字符串')

select rtrim('   aaaa   ');

2.8、左右填充

语法:

  • lpad('字符串',填充后的总长度,'填充的字符串')左填充
  • rpad('字符串',填充后的总长度,'填充的字符串')右填充
select lpad('aaa', 5, '-');
select rpad('aaa', 5, '-');

2.9、字符串替换

语法:replace('字符串', '被替换的字符串', '替换之后的字符串')

select replace('hello java', 'java', 'mysql');

三、数学函数

3.1、四舍五入

语法:round(数字, 小数位数)

# 3
select round(3.145);
# 3.15
select round(3.145, 2);

3.2、向上取整

语法:ceil(数字)

# 3
select ceil(2.02);
# -2
select ceil(-2.02);

3.3、向下取整

语法:floor(数字)

# 5
select floor(5.01);
# 4
select floor(4.99);
# -6
select floor(-5.01);

3.4、取模

语法:mod(被模数,模数)

# 1
select mod(5, 2);

3.5、截断

语法:truncate(数字,截取后小数的位数)

# 3.14
select truncate(3.1456, 2);

3.6、随机数

语法:rand()

生成0~1之间的小数

select rand();

四、日期函数

4.1、当前日期和时间

获取当前日期和时间:now()

获取当前日期:curdate()

获取当前时间:curtime()

select now();
select curdate();
select curtime();

4.2、获取年月日时分秒

年:year(日期)

月:month(日期)

日:day(日期)

时:hour(日期)

分:minute(日期)

秒:second(日期)

select year(now());
select year('2010/10/11 20:11:35');

select month(now());
select day(now());
select hour(now());
select minute(now());
select second(now());
# 查询员工姓名和入职年份
select ename, year(hiredate) from emp;

4.3、日期转换

日期格式的字符转换成日期:str_to_date('日期格式字符串','格式')

# 2020-01-02
select str_to_date('1-2/2020', '%c-%d/%Y');
格式符功能
%a缩写星期名
%b缩写月名
%c月,数值
%D带有英文前缀的月中的天
%d月的天,数值(00-31)
%e月的天,数值(0-31)
%f微秒
%H小时 (00-23)
%h小时 (01-12)
%I小时 (01-12)
%i分钟,数值(00-59)
%j年的天 (001-366)
%k小时 (0-23)
%l小时 (1-12)
%M月名
%m月,数值(00-12)
%pAM 或 PM
%r时间,12-小时(hh:mm:ss AM 或 PM)
%S秒(00-59)
%s秒(00-59)
%T时间, 24-小时 (hh:mm:ss)
%U周 (00-53) 星期日是一周的第一天
%u周 (00-53) 星期一是一周的第一天
%V周 (01-53) 星期日是一周的第一天,与 %X 使用
%v周 (01-53) 星期一是一周的第一天,与 %x 使用
%W星期名
%w周的天 (0=星期日, 6=星期六)
%X年,其中的星期日是周的第一天,4 位,与 %V 使用
%x年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y年,4 位
%y年,2 位

日期转换为字符:date_format(日期, '格式')

select date_format(now(),'%Y年%m月%d日');
select date_format('1999-01-02','%Y年%c月%e日');
# 查询员工姓名和入职日期,以xxxx年xx月xx日显示
select ename, date_format(hiredate, '%Y年%m月%d日') from emp;

五、其他函数

当前数据库版本:version()

当前打开的数据库:database()

当前用户:user()

当前字符串md5加密形式:md5(字符)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2328286.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ubuntu 20.04 出现问号图标且无法联网 修复

在 Ubuntu 中遇到网络连接问题(如出现问号图标且无法联网),可以通过以下命令尝试重启网络服务: 1. 推荐先修改DNS 编辑 -> 虚拟机网络编辑器-> VMnet8 ->NAT 设置 -> DNS 设置 -> 设置DNS 服务器 DNS填什么 取决…

基于Contiue来阅读open-r1中的GRPO训练代码

原创 快乐王子HP 快乐王子AI说 2025年04月03日 23:54 广东 前面安装了vscode[1]同时也安装了Coninue的相关插件[2],现在想用它们来阅读一下open-r1项目的代码[3]。 首先,从启动训练开始(以GRPO为例子) 第一步,使用TRL的vLLM后端…

51c嵌入式~单片机~合集7~※

我自己的原文哦~ https://blog.51cto.com/whaosoft/13692314 一、芯片工作的心脏--晶振 在振荡器中采用一个特殊的元件——石英晶体,它可以产生频率高度稳定的交流信号,这种采用石英晶体的振荡器称为晶体振荡器,简称晶振。 制作方法 …

英菲克(INPHIC)A9无线蓝牙鼠标 链接电脑的方式

英菲克(INPHIC)A9鼠标链接至电脑时,要长按住“模式切换MODE”按钮5秒左右的时间,此时模式指示灯变成蓝色,并且闪烁。 这时使用电脑的蓝牙设置中,“添加设备”,会出现BT4.0 Mouse提示&#xff0…

lua表table和JSON字符串互转

--print("local ssxc{\n"..string.gsub(str,":","").."\n}") Utils {} ---------------------------------------------------------------------------------- -- Lua-Table 与 string 转换 local function value2string(value, isA…

【每日一个知识点】分布式数据湖与实时计算

在现代数据架构中,分布式数据湖(Distributed Data Lake) 结合 实时计算(Real-time Computing) 已成为大数据处理的核心模式。数据湖用于存储海量的结构化和非结构化数据,而实时计算则确保数据能够被迅速处理…

c语言数据结构--------拓扑排序和逆拓扑排序(Kahn算法和DFS算法实现)

#include <stdio.h> #include <string.h> #include <stdbool.h> #include <stdlib.h>//使用卡恩算法(Kahn)和深度优先算法(DFS)实现//拓扑排序和逆拓扑排序//拓扑排序和逆拓扑排序顶点顺序相反//图&#xff0c;邻接矩阵存储 #define MaxVertexNum 100 …

谷粒微服务高级篇学习笔记整理---nginx搭建正反向代理

正向与反向代理 **正向代理:**客户端向代理服务器发请求并指定目标服务器,代理向目标转交请求并将获得的内容转给客户端。 反向代理:用户直接访问反向代理服务器就可以获得目标服务器的资源。反向代理服务器统一了访问入口。 给首页配置反向代理 修改windows的hosts文件配…

2.pycharm保姆级安装教程

一、pycharm安装 1.官网上下载好好软&#xff0c;双击打开 2.下一步 3.修改路径地址 (默认也可以) 4.打勾 5.安装 不用重启电脑 二、添加解释器 1.双击软件&#xff0c;打开 2.projects – new project 3.指定项目名字&#xff0c;项目保存地址&#xff0c;解释器 4.右击 – …

【SQL】取消sql某一列的唯一值key值的方法

在插入数据到sql时&#xff0c;遇到了这个问题&#xff1a; Duplicate entry ‘XXX’ for key 起因是&#xff1a; 我之前设计表的时候&#xff0c;手动给product_title 这个列加了一个key&#xff0c; key 是这个字段的唯一键约束&#xff0c;就不能重复在这一列存入重复的数…

数据库--SQL

SQL&#xff1a;Structured Query Language&#xff0c;结构化查询语言 SQL是用于管理关系型数据库并对其中的数据进行一系列操作&#xff08;包括数据插入、查询、修改删除&#xff09;的一种语言 分类&#xff1a;数据定义语言DDL、数据操纵语言DML、数据控制语言DCL、事务处…

SQL语句(一)—— DDL

目录 一、SQL 基础知识 &#xff08;一&#xff09;SQL 通用语法 &#xff08;二&#xff09;SQL 分类 二、DDL —— 数据库操作 1、查询所有数据库 2、查询当前数据库 3、创建数据库 4、删除数据库 5、切换数据库 三、DDL —— 表操作 &#xff08;一&#xff09;查…

Husky目标跟踪

1.0设备清单 幻影峡谷、适配器 摄像头及数据线、显卡欺骗器 外接屏幕、键盘鼠标 Husky底盘、便携显示屏、键盘鼠标 移动电源 1.1连线 插排——移动电源幻影峡谷——适配器——插排摄像头——幻影峡谷&#xff08;摄像头固定在机械臂前方的底盘上&#xff09;键盘鼠标显示器…

Python----机器学习(线性回归:自求导的方法实现)

一、线性回归方程 目标&#xff1a; 线性回归的目标是找到最佳的系数来使模型与观察到的数据尽可能拟合。 应用&#xff1a; 预测&#xff1a;给定自变量的值&#xff0c;预测因变量的值。 回归分析&#xff1a;确定自变量对因变量的影响程度 线性回归是统计学和机器学习中最简…

Springcache+xxljob实现定时刷新缓存

目录 SpringCache详解 SpringCache概述 核心原理 接口抽象与多态 AOP动态代理 核心注解以及使用 公共属性 cacheNames KeyGenerator&#xff1a;key生成器 key condition&#xff1a;缓存的条件&#xff0c;对入参进行判断 注解 xxl-job详解 SpringcacheRedis实现…

vue2拖拉拽做个模拟公式工具

1. 成图 2. 介绍 就是简单拖拉拽来做个规则运算器&#xff0c;具体运算规则、校验规则自己加。 3. 代码 HTML代码 <template><div class"red-cont"><div class"red-top"><divclass"red-top-left"><div class&quo…

Windows查重工具,强烈推荐大家收藏!

我大家在用电脑的时候&#xff0c;是不是发现用得越久&#xff0c;电脑里的软件和文件就越多&#xff1f; 今天我给大家带来的这两款重复文件查找神器&#xff0c;简直就是电脑里的“清洁小能手”&#xff0c;能帮你把那些重复的文件和文件夹找出来。 Easy DupLicate Finder 重…

使用python完成手写数字识别

入门图像识别的第一个案例,看到好多小伙伴分享,也把自己当初的思路捋捋,写成一篇博客,作为记录和分享,也欢迎各位交流讨论。 实现思路 数据集:MNIST(包含60,000个训练样本和10,000个测试样本) 深度学习框架:Keras(基于TensorFlow) 模型架构:卷积神经网络(CNN) 实…

OpenLayers:如何控制Overlay的层级?

我最近在使用Overlay的时候遇到了一个问题&#xff0c;我向地图中添加了两种不同的Overlay&#xff08;下图中的蓝色标牌和粉色标牌&#xff09;&#xff0c;我希望粉色标牌可以显示在最上层&#xff0c;可偏偏蓝色标牌却将其遮挡住了。于是我对Overlay的层级开始起了兴趣&…

《Golang高性能网络编程:构建低延迟服务器应用》

在本文中&#xff0c;我们将深入探讨Golang高性能网络编程&#xff0c;帮助您构建低延迟服务器应用。我们将介绍Golang的网络编程特性、优化技巧和实际案例&#xff0c;让您更好地理解和应用Golang在网络编程领域的优势。 高性能网络编程简介 什么是Golang高性能网络编程 高性能…