【MySQL】数据库精细化讲解:内置函数知识穿透与深度学习解析

        前言:本节内容讲述mysql里面的函数的概念, 在mysql当中, 内置了很多函数工作。 这些函数丰富了我们的操作。 比如字符串函数、数据函数以及一些其他函数等等。

        ps:友友们学习了表的基本操作后就可以观看本节内容啦!

目录

日期函数

current_date和current_time

current_timestamp

now函数

date提取日期

date_add和date_sub时间推导

datediff时间相减

字符串函数

charset(str) 返回字符串的字符集

concat拼接字符串

length求字符串长度

replace替换字符

substring字符串截取

ltrim和rtrim

数学函数

abs

bin十进制转二进制

conv将一个数字从某个进制转化为另一个进制

ceiling和floor取整

其他函数

user()

database();

md密码加密


日期函数

current_date和current_time

        在mysql中, 使用select可以直接使用current函数:

select current_date;

     

        同样的, 也可以直接使用current_time:

select current_time;

         上面current_date是显示当前的日期, current_time是现实当前的时间, 所以, 两个函数一起使用就能查看当前的日期以及时间:

select current_date, current_time;

current_timestamp

        我们除了可以上面的两个函数一起使用, 也可以使用current_timestamp查看时间戳:

select current_timestamp;

now函数

        我们也可以使用now函数, 查看当前的时间:(now函数必须加括号)

select now();

date提取日期

        我们也可以使用date(日期和时间)来截取当前的日期:

select date('1999-10-1 06:06:06');

date_add和date_sub时间推导

        date_add可以进行时间的加法推导, 就是当前的时间加上一个日期, 分钟或者秒之后是什么日期,什么时间。 如下为例子:

select date_add('2020-10-1', interval 10 day);
select date_add('2020-10-1', interval 40 day);
select date_add(now(), interval 10 day);
select date_add(now(), interval 10 minute);

select date_sub(now(), interval 10 day);
select date_sub(now(), interval 1000 day);
select date_sub(now(), interval 10000 day);
select date_sub(now(), interval 10000 minute);

datediff时间相减

        datediff可以进行时间的相减:

select datediff(now(), '2000-1-1');

字符串函数

charset(str) 返回字符串的字符集

        

select charset(字符串);

 

        charset能返回字符的编码格式。

concat拼接字符串

        concat能够连接字符串, 可以跟两个参数, 拼接两个字符串;也可以跟三个参数, 拼接三个字符串, 也可以跟更多....。

select concat('字符串', '字符串2');
select concat('字符串', '字符串2', '字符串3');
select concat('字符串', '字符串2', '字符串3', ...);

length求字符串长度

        注意, length求的是字节, 不是字符个数。 

select length(字符串);


      

replace替换字符

        replace能够替换字符

就比如我们将我们员工表中含有'S'的数据替换成上海:

select replace(ename, 'S', '上海'), ename from emp;

        replace 三个参数中第一个参数是原数据列, 第二个参数是被替换的字符, 第三个参数是目标的字符。

substring字符串截取

        substring能够截取一个字符串, 从第几个位置截取到第几个位置:

substring('字符串', 起始位置, 截取长度);

        将字符串分割:

select ename, substirng(ename, 1, 1), substring(ename,2) from emp; 第三个参数不写表示截取到最后一个字符。

ltrim和rtrim

        ltrim和rtrim可以去掉字符串中的左右空格:

数学函数

abs

        abs取绝对值, 不解释:

select abs(10);
select abs(-10);

bin十进制转二进制

select bin(20);
select bin(10);
select bin(1);
select bin(2);

conv将一个数字从某个进制转化为另一个进制

select conv(数字, 进制1, 进制2);

ceiling和floor取整

        我们从负数到整数。 我们一般取整就是四舍五入。 但是我们celling使用的是将小数去掉。 即对于正数来说, 是向下取整。对于负数来说, 是向上取整。正数和负数都向零趋近, 所以, 这种取整方式叫做向零取整。

        另一种取整方式是向上取整, 就是对于负数-3.1, 去掉小数位-3。 对于正数3.1, 向上取整为4。

        ceiling是向上取整:

        floor是向下取整 

 、

其他函数

user()

查看当前用户:

select user();

database();

select database();

md密码加密

        我们在向数据库中进行插入密码的时候, 一定要使用md进行加密。 否则如果数据库被人盗走, 那么这个服务里面的所有用户的密码账号就全部被盗取了, 这个危害就太大了。 所以我们如果要插入密码, 一定要使用md进行转码:

create table user3(
id int primary key auto_increment,
password varchar(32)
);

insert into user3(password) values('helloworld');
insert into user3(password) values(md5('helloworld'));

        然后我们就能看到如下图为两个密码的区别, id为1是没有加密的密码; id为2是加密后的密码, 这个密码只能由数据库自己识别。 这个md5转化成的这个加密字符串一定是等长的, 即便原字符串只有1个字符, 转化后的字符串也是等长的。 

        未来我们想要利用密码筛选信息怎么筛选呢? 同样是使用md5:

select id from user3 where password = md5('helloworld');

  ——————以上就是本节全部内容哦, 如果对友友们有帮助的话可以关注博主, 方便学习更多知识哦!!!   

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Is:cannat access /data: Input/output error

说明: 1)访问应用业务,输入账号密码报如下图所示:invalid login. 2)登录服务器查看数据日志,报如下图所示:ls:cannot access /data: Input/output error 3)查看日志dmesg |grep erro…

Python MySQL SQLServer操作

Python MySQL SQLServer操作 Python 可以通过 pymysql 连接 MySQL,通过 pymssql 连接 SQL Server。以下是基础操作和代码实战示例: 一、操作 MySQL:使用 pymysql python 操作数据库流程 1. 安装库 pip install pymysql2. 连接 MySQL 示例 …

迅为RK3562开发板直连电脑配置方法(无线上网)

概述 由于环境限制,笔记本电脑和开发板无法通过路由器连接起来,所以本文的目的是要实现笔记本电脑和虚拟机能够通过 WIFI 上网,并且开发板通过网线连接笔记本电脑和虚拟机在同一个网段内,最终实现 TFTP 或 NFS 来进行开发调试。 通…

Mono Repository方案与ReactPress的PNPM实践

ReactPress Github项目地址:https://github.com/fecommunity/reactpress 欢迎Star。 Mono Repository方案与ReactPress的PNPM实践 在当今软件开发领域,Mono Repository(简称Monorepo)已成为一种流行的代码管理方式,特…

timedatectl命令修改时间和时区

1.默认情况下,Linux系统通常每64分钟进行一次NTP时间同步。但是,这可以通过编辑/etc/ntp.conf文件来修改。在/etc/ntp.conf中设置minpoll和maxpoll参数。 timedatectl可以用来查询和更改系统时间设定,同时可以设定和修改时区信息。 一、查…

基于Opencv的图像处理软件

目录 一、背景及意义介绍背景意义 二、概述一、背景及意义介绍背景意义 三、论文思路解决问题 四、复现过程(一)图像处理模块二)图形界面模块(一)图像处理模块实现步骤(二)图形界面模块实现步骤…

HTML的自动定义倒计时,这个配色存一下

<!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>自定义倒计时</title><style>* {mar…

私有化部署视频平台EasyCVR宇视设备视频平台如何构建视频联网平台及升级视频转码业务?

在当今数字化、网络化的时代背景下&#xff0c;视频监控技术已广泛应用于各行各业&#xff0c;成为保障安全、提升效率的重要工具。然而&#xff0c;面对复杂多变的监控需求和跨区域、网络化的管理挑战&#xff0c;传统的视频监控解决方案往往显得力不从心。 EasyCVR视频融合云…

MacOS通过X11转发远程运行virt-manager进行虚机分配

今天需要通过本地macbook机器连接远程物理机&#xff0c;执行虚机分配&#xff0c;现有文档仅提供window环境安装&#xff0c;如下整理Mac环境下的安装步骤 操作篇 前提条件 支持x11转发的terminal&#xff0c;我本地使用iTerm2&#xff1b;本地安装XQuartz&#xff0c;作为…

【每天学点AI】实战图像增强技术在人工智能图像处理中的应用

图像增强&#xff08;Image Enhancement&#xff09;是人工智能和计算机视觉中一项重要的技术&#xff0c;也是人工智能数据集预处理的一个重要步骤。它旨在提高图像的质量&#xff0c;使其在视觉上更加清晰、细节更丰富。这项技术在自动驾驶、医疗诊断、安防监控等领域有着广泛…

hbase mongodb hive starrocks比较

本文是在学习大数据的几个数据存储系统相关的组件所记录下来的&#xff0c;主要是不同组件的基础概念初步了解与对比。 NoSql 在大数据时代&#xff0c;虽然RDBMS很优秀&#xff0c;但是面对快速增长的数据规模和日渐复杂的数据模型&#xff0c;RDBMS渐渐力不从心&#xff0c…

STM32端口模拟编码器输入

文章目录 前言一、正交编码器是什么&#xff1f;二、使用步骤2.1开启时钟2.2配置编码器引脚 TIM3 CH1(PA6) CH2 (PA7)上拉输入2.3.初始化编码器时基2.4 初始化编码器输入2.5 配置编码器接口2.6 开启定时器2.7获取编码器数据 三、参考程序四、测试结果4.1测试方法4.2串口输出结果…

wireshark使用lua解析自定义协议

wireshark解析自定义协议 1.自定义的lua放入路径2.修改init.lua2.1 开启lua2.2 init.lua文件最后加入自己的lua文件位置&#xff0c;这里需要确保与自己的文件名相同 3.编写lua4.编写c抓包5.wireshark添加自定义协议如何加调试信息 1.自定义的lua放入路径 一般是自己软件的安装…

基于docker进行任意项目灵活发布

引言 不管是java还是python程序等&#xff0c;使用docker发布的优势有以下几点&#xff1a; 易于维护。直接docker命令进行管理&#xff0c;如docker stop、docker start等&#xff0c;快速方便无需各种进程查询关闭。环境隔离。项目代码任何依赖或设置都可以基本独立&#x…

友思特新闻 | 友思特荣获广州科技创新创业大赛智能装备行业赛初创组优胜企业!

2024年11月19日&#xff0c;第十三届中国创新创业大赛&#xff08;广东广州赛区&#xff09;暨2024年广州科技创新创业大赛智能装备行业赛颁奖典礼隆重举行。 赛事奖项介绍&#xff1a;广州科技创新创业大赛智能装备行业赛 第十三届“中国创新创业大赛&#xff08;广东广州赛区…

FreeRTOS——消息队列

目录 一、概念及其作用 1.1概念 1.2特点 1.3工作原理 二、相关API 2.1创建队列 2.2任务中写队列 2.3任务中读队列 2.4中断中写队列 2.5中断中读队列 三、实现原理 3.1消息队列控制块 3.2消息队列的创建 3.3消息的发送 3.3.1任务中发送 3.3.2中断中发送 3.4消息的…

11 —— 打包模式的应用

需求&#xff1a;在开发模式下想让webpack使用style-loader进行css样式的处理&#xff1b;让它把css代码内嵌在js中&#xff1b;在生产模式下提取css代码 —— 判断当前运行命令时所在的环境 方案&#xff1a;借助cross-env全局软件包&#xff0c;设置参数区分打包运行环境 …

# issue 4 进程控制函数

目录 一、进程控制函数一 二、进程控制函数二 启动进程&#xff1a;&#xff08;exec系列&#xff09; 创建新进程&#xff1a; 测试代码&#xff1a; 测试结果&#xff1a; 三、进程控制函数三 结束进程&#xff1a; 测试代码&#xff1a; 测试结果&#xff1a; 四、…

C#实现blob分析——分别基于OpenCvSharp和Emgu实现

需求和效果预览 对于下图&#xff0c;需要检测左右两侧是否断开&#xff1a; 解决分析 设置左右2个ROI区域&#xff0c;找到ROI内面积最大的连通域&#xff0c;通过面积阈值和连通域宽高比判定是否断开。 可能遇到的问题&#xff1a;部分区域反光严重&#xff0c;二值化阈值不…

ZYNQ-7020嵌入式系统学习笔记(1)——使用ARM核配置UART发送Helloworld

本工程实现调用ZYNQ-7000的内部ARM处理器&#xff0c;通过UART给电脑发送字符串。 硬件&#xff1a;正点原子领航者-7020 开发平台&#xff1a;Vivado 2018、 SDK 1 Vivado部分操作 1.1 新建工程 设置工程名&#xff0c;选择芯片型号。 1.2 添加和配置PS IP 点击IP INTEGR…