【MySQL】数据处理的瑞士军刀——常用的内置函数(下)

文章目录

  • [1. 数学函数](#1. 数学函数)
    • [1.1 abs():绝对值函数](#1.1 abs():绝对值函数)
    • [1.2 bin():参数转二进制](#1.2 bin():参数转二进制)
    • [1.3 bin():参数转十进制](#1.3 bin():参数转十进制)
    • [1.4 conv(num,from_base,to_base):进制转换](#1.4 conv(num,from_base,to_base):进制转换)
    • [1.5 ceiling():向上取整](#1.5 ceiling():向上取整)
    • [1.6 floor():向下取整](#1.6 floor():向下取整)
    • [1.7 format(number,decimal_places):格式化,保留小数位数](#1.7 format(number,decimal_places):格式化,保留小数位数)
    • [1.8 mod(number,deno):取模](#1.8 mod(number,deno):取模)
    • [1.9 rand():返回随机浮点数,范围[0.0~1.0】](#1.9 rand():返回随机浮点数,范围[0.0~1.0】)
  • [2. 其它函数](#2. 其它函数)
    • [2.1 user() :查询当前用户](#2.1 user() :查询当前用户)
    • [2.2 md5(str):数据指纹](#2.2 md5(str):数据指纹)
    • [2.3 ifnull(val1, val2)](#2.3 ifnull(val1, val2))
  • [3. 实战OJ](#3. 实战OJ)

1. 数学函数

1.1 abs():绝对值函数

例子:

1.2 bin():参数转二进制

例子:

1.3 bin():参数转十进制

例子:

1.4 conv(num,from_base,to_base):进制转换

把数字num从一个进制转(from_base)到另一个进制(to_base):

例如,把6从10进制转换成2进制

sql 复制代码
select conv(6,10,2);

1.5 ceiling():向上取整

sql 复制代码
select ceiling(2.3);

1.6 floor():向下取整

sql 复制代码
select floor(2.7);

1.7 format(number,decimal_places):格式化,保留小数位数

例子:

sql 复制代码
select format(3.1415926,2);

1.8 mod(number,deno):取模

例子:

sql 复制代码
select mod(10,3);

1.9 rand():返回随机浮点数,范围[0.0~1.0】

例子:

sql 复制代码
select rand();

范围是【0.0~1.0】,那如果想生成【0.0~100.0】范围内的小数呢?

乘个100就行了

当然如果嫌后面小数位太多,也可以使用format控制格式:

2. 其它函数

2.1 user() :查询当前用户

sql 复制代码
 select user();

当前我登录的用户是root

2.2 md5(str):数据指纹

下面通过一个场景给大家讲解:

数据库一般在保存一些用户的比如某个应用的账号密码时,密码通常是不能明文保存的。如果明文保存的话,万一你这个表被别人盗取了,那用户的密码就全部泄露了,所以保存的密码通常会进行加密。
比如:
我们先来建一张表

然后我们插入一些数据

插入的密码如果不做处理,直接插入明文保存。那么如果你的表被别人拿到,那直接就可以查看密码。
所以这样是不安全的。
那md5(str)这个函数就可以派上用场了。
md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串(数据指纹)

这样我们存入的就不是真正的密码,而是密码的MD5 值。不论密码多长,最终得到的都是一个32位等长的字符串。
当然MD5() 函数虽然因其安全性问题不再适用于安全领域,但在快速校验、去重、生成标识等非对抗性场景中仍有实用价值。

2.3 ifnull(val1, val2)

如果val1为null,则返回val2,否则返回val1的值

3. 实战OJ

SQL250 查找字符串中逗号出现的次数

怎么做呢?思路:

用字符串的总长度-去掉逗号后的长度(使用replace函数把字符串中的逗号替换为空串)

sql 复制代码
select 
    id,
    length(string)-length(replace(string,',','')) as cnt 
from 
    strings;
相关推荐
weiggle9 小时前
第三篇:可组合函数(Composable)——Compose 的基石
android·前端
独隅10 小时前
Android Studio 接入多种不同 AI 大模型进行开发的全面详细指南(Android Studio+AI)
android·人工智能·android studio
夜微凉410 小时前
三、MySQL
android·数据库·mysql
暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第11讲:正则表达式与正则函数
数据库·mysql
我命由我1234510 小时前
Android 开发问题:项目同时引入了两个包含相同类文件的库(AndroidX 库、旧版本支持库),导致了重复类错误
android·java·java-ee·android studio·android-studio·androidx·android runtime
IT龟苓膏10 小时前
MySQL InnoDB 内存结构与性能调优:Buffer Pool、脏页、刷盘、临时表和 filesort 一篇讲清
数据库·mysql
anthonyzhu10 小时前
安卓Android studio panda run无法应用更新的问题
android·ide·android studio
加号310 小时前
【MySQL】 审计功能深度解析:从原理到落地实践
数据库·mysql
还是鼠鼠11 小时前
AI掘金头条新闻系统 (Toutiao News)-获取用户信息
后端·python·mysql·fastapi·web
雨辰AI11 小时前
MySQL 迁移至达梦 DM9 完整改造指南|99% SQL 零改动
java·开发语言·数据库·sql·mysql·政务