【半夜学习MySQL】内置函数(含日期、字符串、数学等函数常用用法介绍及示例详解)

news2024/12/23 23:43:27

在这里插入图片描述

🏠关于专栏:半夜学习MySQL专栏用于记录MySQL数据相关内容。
🎯每天努力一点点,技术变化看得见

文章目录

  • 日期函数
  • 字符串函数
  • 数学函数
  • 其他函数


日期函数

函数名称描述
current_date()当前日期
current_time()当前时间
current_time()当前时间戳
date(datetime)返回datetime参数的日期
date_add(date, interval d_value_type)在date中添加日期或事件,interval后的数值单位可以是year、minute、second、day
date_sub(date, interval d_value_type在date中减去日期或事件,interval后的数值单位可以是year、minute、second、day
datediff(date1, date2)两个日期的差,单位是天
now()当前日期事件

使用示例:
●获取年月日

select current_date();

在这里插入图片描述

●获取时分秒

select current_time();

在这里插入图片描述

●获取时间戳

select current_timestamp();

在这里插入图片描述

●在日期的基础上加上时间

select date_add('2024-1-1', interval 10 day);

在这里插入图片描述

●在日期的基础上减去时间

select date_sub('2024-1-15', interval 10 day);

在这里插入图片描述

●计算两个日期之间相差多少天

select datediff('2024-1-15', '2024-1-1');

在这里插入图片描述
案例1: 创建一张表,用于记录会员编号和会员注册日期
●创建一张会员表

create table vip(
id int unsigned primary key auto_increment,
sign_date date not null
);

在这里插入图片描述
●插入数据

insert into vip(sign_date) values(current_date());
insert into vip(sign_date) values(current_time());
insert into vip(sign_date) values(current_timestamp());
select * from vip;

在这里插入图片描述
★ps:虽然current_date()、current_time()、current_timestamp()均可时间日期的插入,但这里推荐使用current_date()。

案例2: 创建一个留言板
●创建一个留言表

create table msg(
id int unsigned primary key auto_increment,
content varchar(50) not null,
sendtime datetime
);

在这里插入图片描述
●插入数据

insert into msg(content, sendtime) values('沸羊羊', now());
insert into msg(content, sendtime) values('双面龟', now());
select * from msg;

在这里插入图片描述
●显式所有留言信息,只显式日期,不显示时间

select id, content, date(sendtime) from msg;

在这里插入图片描述
●查询5分钟内发布的贴子

#方法1
select * from msg where date_add(sendtime, interval 5 minute) > now();
#方法2
select * from msg where date_sub(now(), interval 5 minute) < sendtime;

在这里插入图片描述

字符串函数

函数名称描述
charset(str)返回字符串字符集
concat(str [, …])连接字符串
instr(str, substr)返回substr在str中出现的位置, 没有则返回0
ucase(str)转换为大写
lcase(str)转换为小写
left(str, len),从str中左边起取len个字符
length(str)str的长度
replace(str, search_str, replace_str)在str中用replace_str替换search_str
strcmp(str1, str2)逐字符比较两字符串大小
substring(str, position [,length]从str的position位置开始,取length个字符
ltrim(str) / rtrim(str ) / trim(str)去除前空格/后空格/前后空格

案例1: 获取emp表的ename列的字符集

select charset(ename) from emp;

在这里插入图片描述
案例2: 显式emp表中的信息,显示格式:“员工号为:XXX,姓名为:XXX的员工,岗位为XXX”

select concat('员工号为:', empno, ',姓名为:', ename, '的员工,岗位为', job) from emp;

在这里插入图片描述
案例3: 显示员工姓名作战的字节数

select length(ename), ename from emp;

在这里插入图片描述
★ps:length函数返回字符串所占的字节数。字母、数字算一个字符,而其他字符,如中文,需要使用多个字符表示(具体与字符集编码有关)。

案例4: 将emp表中所有姓名中有S的替换为“Jammingpro”

select replace(ename, 'S', 'Jammingpro'), ename from emp;

在这里插入图片描述
★ps:replace函数对数据的修改仅停留在显示层面,并不会修改表中数据。

案例5: 截取emp表中ename字段的第二个到第三个字符

select substring(ename, 2, 2), ename from emp;

在这里插入图片描述
案例6: 以首字母大写的方式,余下字母小写显示所有员工的姓名

select concat(ucase(substring(ename, 1, 1)), lcase(substring(ename, 2))) from emp;

在这里插入图片描述

数学函数

函数名称描述
abs(num)绝对值函数
bin(decimal_num)十进制转换二进制
hex(decimal_num)十进制转换为十六进制
cov(num, from_base, to_base)进制转换
ceiling(num)向上取整
floor(num)向下取整
format(num, decimal_places)格式化,保留小数位数
rand()返回随机浮点数,范围[0.0, 1.0]
mod(num, denominator)取模,求余

使用示例:
●绝对值

select abs(-100.12);
select abs(2000.88);

在这里插入图片描述

●向上取整

select ceiling(10.1);
select ceiling(10.9);
select ceiling(-4.1);
select ceiling(-4.9);

在这里插入图片描述

●向下取整

select floor(10.1);
select floor(10.9);
select floor(-4.1);
select floor(-4.9);

在这里插入图片描述
★ps:取整分为零向取整、向上(向下)的整数取整、四舍五入。其中零向取整,10.1、10.9均向更靠近0的数字10取整,-4.1、-4.9向更偏向0的整数4取整。向上取整,10.1、10.9向大于该数的整数11取整,-4.1、-4.9向大于该数的整数-4取整。向下取整,10.1、10.9向小于该数的整数10取整,-4.1、-4.9向小于该数的整数-5取整。ceiling函数采用向上取整,floor函数采用向下取整。四舍五入取整方式这里不再赘述。
在这里插入图片描述

●保留2位小数(小数四舍五入)

select format(10.256, 2);
select format(12.123, 2);

在这里插入图片描述

●产生随机数

select rand();
select rand();
select rand();

在这里插入图片描述

★ps:rand函数用于生产[0,1)间的随机数,rand函数生成的随机数是浮点数。

●模运算

select mod(10, 3);

在这里插入图片描述

其他函数

●user()查询当前登陆用户

select user();

在这里插入图片描述

●md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串

select md5('jammmingpro');
select md5('a');
select md5('');

在这里插入图片描述

●database()显示当前正在使用的数据库名称

select database();

在这里插入图片描述

●pwssword()函数用于对用户密码做加密,但该函数于MySQL5.7.6开始已经被弃用,因为它使用的哈希算法(DOUBLE SHA1)被认为较弱,不再适合用于密码存储。

select password('jammingpro');

在这里插入图片描述

●ifnull(val1, val2),如果val1为null,返回val2,否则返回val1的值

select ifnull('xiaoming', 'jammingpro');
select ifnull(null, 'jammingpro');

在这里插入图片描述

🎈欢迎进入半夜学习MySQL专栏,查看更多文章。
如果上述内容有任何问题,欢迎在下方留言区指正b( ̄▽ ̄)d

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

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

相关文章

Linux平台和Windows平台互传文件

rz和sz的出发对象都是从Linux出发的&#xff0c;例如sz发送&#xff08;Send&#xff09;从Linux->发送到Windows。 rz 从Windows文件发送到Linux中 先创立一个新文本文件 之后将hello Windows输入到该文本文件中 在显示器上显示里面是否有hello Windows内容 sz发送Lin…

yolov8使用与训练步骤

第一&#xff1a;安装miniconda 网址&#xff1a;Index of /anaconda/miniconda/ 登录网址后 在网页按ctrF 输入&#xff1a;搜py38 Miniconda3-py38_22.11.1-1-Windows-x86_64.exe 52.5 MiB 2022-12-23 07:57 下载进行安装 安装过程中记得加环境变量这个项。 第二…

2024年最新软件测试面试题必问的1000题!

我了解的测试理论和方法包括以下几个方面&#xff1a; 黑盒测试与白盒测试&#xff1a; 黑盒测试&#xff1a;基于对软件系统外部行为进行测试&#xff0c;独立于内部代码实现细节。黑盒测试关注输入与输出之间的关系以及软件功能是否符合预期。白盒测试&#xff1a;基于对软件…

k8s 部署 CoreDNS master02 节点部署 负载均衡部署

目录 一、部署 CoreDNS 1.1.在所有 node 节点上操作 1.2.在 master01 节点上操作 1.3.DNS 解析测试 二、master02 节点部署 2.1.从 master01 节点上拷贝证书文件、各master组件的配置文件和服务管理文件到 master02 节点 2.2.修改配置文件kube-apiserver中的IP 2.3.在 …

RT-Thread中使用Mqtt

环境&#xff1a; 开发板&#xff1a;Panduola&#xff08;stm32L475&#xff09; KEIL5 开发环境 rtthread 4.0.3内核 使用ENV 配置Rtt MQTT 1.MQTT介绍 ​ 客户端 Client 使用MQTT的程序或设备。客户端总是通过网络连接到服务端。它可以发布应用消息给其它相关的客户端。订…

记笔记从学Typora开始--------------------(1)下载、安装、购买、激活

一、登录Typora官网 官网地址&#xff1a;Typora 二、鼠标往下滑&#xff0c;点击下载按钮 三、下载得到安装包&#xff0c;双击 四、一直点击下一步&#xff0c;进行安装 五、安装完成 六、启动Typoera 七、针对欢迎界面点击下一页 八、一直点击直到弹出以下软件激活界面 九…

企业OA办公系统开发笔记:1、搭建后端环境

文章目录 企业办公系统&#xff1a;搭建环境一、项目介绍1、介绍2、技术栈3、项目模块4、数据库 二、搭建环境1、搭建后端1.1、搭建父工程clfwzx-oa-parent1.2、搭建工具类父模块common1.3、搭建工具类common的子模块1.4、搭建实体类模块model和项目模块service-oa 2、配置依赖…

经济寒冬 | 品牌策划人还可以去哪些行业发展?

在这个经济寒冬下&#xff0c;咱们品牌策划人也需要考虑后路问题了。 随着市场竞争的加剧和消费者需求的不断变化&#xff0c;品牌策划人的工作不再只是简单的广告宣传和市场推广。 咱们需要重新思考自己的角色&#xff0c;寻找新的生存和发展之道。 当然&#xff0c;品牌策…

基于Python的jieba库分析《斗破苍穹》文本中的高频词汇

分析《斗破苍穹》文本中的高频词汇 在进行文本分析时&#xff0c;了解文本中出现频率较高的词汇对于把握文本的主题和风格非常有帮助。本文将介绍如何使用Python的jieba库对《斗破苍穹》这部小说的文本进行分词处理&#xff0c;并统计高频词汇的出现次数&#xff08;本文只统计…

idea连接远程仓库

git ->克隆。 url为远程仓库的地址&#xff0c;输入好后&#xff0c;选择项目存放目录&#xff0c;再点击克隆 点击新窗口打开。 切换到对应分支

[AI开发配环境]jupyter notebook远程连接ssh

照这个操作&#xff1a; https://blog.csdn.net/wuqrcn/article/details/135512396 步骤 安装并生成配置文件 注意&#xff0c;在base环境中安装&#xff0c;这样在其他所有环境中都能用&#xff0c;到时候选环境即可。 pip install jupyter notebook # 安装jupyter notebo…

TopOn 正式聚合Kwai 旗下程序化广告平台——Kwai Network

**我们非常高兴的宣布&#xff0c;TopOn SDK 近日已正式聚合Kwai Network。**作为Kwai 旗下的程序化广告平台&#xff0c;Kwai Network 通过优质的变现能力及产品能力&#xff0c;为广大开发者提供高效及时的服务。 TopOn 聚合平台与Kwai Network 正式完成接入后&#xff0c;开…

SOP for Oracle 23ai:Python 连接 Oracle 的两种方法

前情回顾 前文介绍了如何使用 python-oracledb 连接 Oracle 23ai 数据库&#xff0c;并演示了如何使用独立连接方式。 其中提到了支持两种连接池&#xff1a; DRCP 和 PRCP。 本文将对这两种连接池做具体演示。 DRCP 和 PRCP 连接池 连接池技术的优点不言而喻&#xff1a; 缩短…

mysql----武侠剑客之-----MEMORY 存储引擎

文章目录 mysql--------MEMORY 存储引擎1、1 特点&#xff1a;1、2 代码演示&#xff1a; mysql--------MEMORY 存储引擎 1、1 特点&#xff1a; 1.frm文件存储表的结构信息 2 数据存放在内存中&#xff0c;没有表数据文件&#xff0c;重启后&#xff0c;数据丢失 3 使用表…

探索Playwright:Python下的Web自动化测试革命

在如今这个互联网技术迅速发展的时代&#xff0c;web应用的质量直接关系着企业的声誉和用户的体验。因此&#xff0c;自动化测试成为了保障软件质量的重要手段之一。今天&#xff0c;我将带大家详细了解一款在测试领域大放异彩的神器——Playwright&#xff0c;并通过Python语言…

栈和队列经典面试题详解

目录 题目一&#xff1a;20. 有效的括号 - 力扣&#xff08;LeetCode&#xff09; 题目二&#xff1a;225. 用队列实现栈 - 力扣&#xff08;LeetCode&#xff09; 题目三&#xff1a;232. 用栈实现队列 - 力扣&#xff08;LeetCode&#xff09; 题目四&#xff1a;622. 设…

网络安全 会飞的狗狗 网络安全狗是什么

1.概述 网站安全狗是一款集网站内容安全防护、网站资源保护及网站流量保护功能为一体的服务器工具。功能涵盖了网马/木马扫描、防SQL注入、防盗链、防CC攻击、网站流量实时监控、网站CPU监控、下载线程保护、IP黑白名单管理、网页防篡改功能等模块。能够为用户提供实时的网站安…

Springboot+Vue项目-基于Java+MySQL的火锅店管理系统(附源码+演示视频+LW)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &…

多线程的代码案例

目录 单例模式 饿汉模式 懒汉模式 阻塞队列 生产者消费者模型意义: 阻塞队列使用方法 实现阻塞队列 阻塞队列实现生产者消费者模型 定时器 实现简单的定时器 工厂模式 线程池 为啥呢? 从池子里面取 比 创建线程 效率更高 线程池的创建 怎么填坑 ThreadPoolExec…

[HNCTF 2024] crypto/pwn

周日的比赛&#xff0c;赛后拿别人的WP又作了俩&#xff0c;最后一个题也是没弄懂&#xff0c;先记一下吧。 Crypto EZmath 一个简单的函数题。在sagemath里有个two_squares函数&#xff0c;可以从平方和恢复两个规模相近的数。这种比较适合于RSA里的p,q。另外未知的e用来猜…