【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)

前言

大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++ Linux的老铁

主要内容含:

一.数据库函数的应用场景&常见函数盘点介绍

1.函数基本概念

  • 函数 是指一段可以直接被另一段程序调用的程序或代码。
  • 我们通常借助mysql的 内部自带函数 来计算

2.常见函数一览

  • 如下所示

3.数据库函数的应用场景

  • 如下所示

二.字符串函数

1.字符串函数盘点&语法

  • 如下所示
SELECT函数(参数);


2.调用字符串函数案例cv语句&substring注意点

-- concat
select concat('Hello' , ' NySQL');

-- lower
select Lower('HelLo');

-- upper
select upper('Hello');

-- lpad
select lpad('01', 5, '-');

-- rpad
select rpad('01', 5,'-');

- substring
- select substring('Hello NysQL',1,5); //注意索引号从1开始

substring注意点:

  • 注意索引号从1开始

3.调用字符串函数效果演示

  • 效果一览

4.需求练习

--1.由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如:1号员工的工号应该为00001。
update emp set workno = Lpad(workno, 5,1 '0');

三.数值函数

1.数值函数盘点

  • 如下所示:

2.调用数值函数案例cv语句

-- ceil
select ceil(1.1);

-- floor
select floor(1.9);

-- mod
select mod(3,4);

-- rand
select rand();

-- round
select round(2.34,2);

3.调用数值函数效果演示

  • 如下所示

4.需求练习

--1.通过数据库的函数,生成一个六位数的随机验证码
select round(rand()*1000000 , 0);
-- 我们一开始可能会这样编写,但会出现5位数情况;随机数介于0-1之间,可能0.019255
-- 我们要补0到6位数

-- 改善后 (左补0)
select Lpad(round(rand()*1000000, 0), 6, '0');

四.日期函数

1.日期函数盘点

  • 如下所示:

2.调用日期函数案例cv语句

--日期函数
-- curdate()
select curdate();

-- curtime()
select curtime();

-- now()
select now();

-- 年月日
seLect YEAR(now());

select MONTH(now());

select DAY(now());

-- 加/减日期
-- date_add
select date_add(now(), INTERVAL 70 YEAR );

-- datediff
select datediff('2021-12-01', '2021-11-01');

3.需求练习

案例:查询所有员工的入职天数,并根据入职天数倒序排序
select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by entrydays desd;

五.流程控制函数

1.流程控制函数盘点

  • 如下所示

2.调用流程控制函数演示&“空串也算串”注意事项

--流程控制函数
-- if
select if(false,'Ok','Error');

-- ifnull
select ifnull('Ok','Default');

select ifnull('','Default');

select ifnull(null,'Default');
  • “空串也算串”注意事项 :
  • select ifnull('','Default');返回结果
  • select ifnull(null,'Default');返回结果

3.需求练习1

-- case when then else end
--需求:查询emp表的员工姓名和工作地址(北京/上海---->一线城市,其他---->二线城市)
select
    name,
    case workaddress when'北京'then'一线城市'when'上海'then'一线城市'else'二线城市'end
from emp;

-- 取别名
select
    name,
    (case workaddress when'北京'then‘一线城市'when‘上海'then'一线城市'else‘二线城市'end)as‘工作地址'
    from emp;

4.需求练习2

1.环境植入

  • 如下所示我们先植入环境
create table score(
       id int comment 'ID',
       name varchar(20)comment'姓名',
       math int comment'数学',
       english int comment'英语',
       chinese int comment'语文'
)comment'学员成续表';
insert into score(id, name, math, english, chinese) VALUES (1, 'Tom', 67, 88, 95 ), (2, 'Rose' , 23, 66, 99),(3, 'Jack',56,98,76);

2.需求练习正文

  • 我们要将成绩换算成
  1. 大于85分"优秀"
  2. 大于60分小于85分"及格"
  3. 小于60分"不及格"
select
   id,
   name,
   (case when math >=85 then'优秀'when math >=60 then'及格'else'不及格'end)'数学',
   (case when english>= 85 then'优秀'when english >=60 then'及格'else'不及格'end)'英语',
   (case when chinese >=85 then'优秀'when chinese >=60 then'及格'else'不及格'end)'语文'
from score;

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
25 0
|
4天前
|
Java 关系型数据库 MySQL
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口(下)
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口
13 0
|
4天前
|
Java 关系型数据库 MySQL
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口(上)
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口
20 0
|
2天前
|
关系型数据库 MySQL API
实时计算 Flink版产品使用合集之可以通过mysql-cdc动态监听MySQL数据库的数据变动吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
16 0
|
4天前
|
前端开发 关系型数据库 MySQL
【MySQL × SpringBoot 突发奇想】全面实现流程 · 数据库导出Excel表格文件的接口
【MySQL × SpringBoot 突发奇想】全面实现流程 · 数据库导出Excel表格文件的接口
26 0
|
4天前
|
关系型数据库 MySQL 数据库
mysql 设置环境变量与未设置环境变量连接数据库的区别
设置与未设置MySQL环境变量在连接数据库时主要区别在于命令输入方式和系统便捷性。设置环境变量后,可直接使用`mysql -u 用户名 -p`命令连接,而无需指定完整路径,提升便利性和灵活性。未设置时,需输入完整路径如`C:\Program Files\MySQL\...`,操作繁琐且易错。为提高效率和减少错误,推荐安装后设置环境变量。[查看视频讲解](https://www.bilibili.com/video/BV1vH4y137HC/)。
24 3
mysql 设置环境变量与未设置环境变量连接数据库的区别
|
4天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
19 0
|
4天前
|
存储 缓存 关系型数据库
MySQL结构流程,看这一篇就够了!
MySQL结构流程,看这一篇就够了!
|
4天前
|
存储 Oracle 关系型数据库
oracle 数据库 迁移 mysql数据库
将 Oracle 数据库迁移到 MySQL 是一项复杂的任务,因为这两种数据库管理系统具有不同的架构、语法和功能。
24 0
|
4天前
|
SQL 存储 小程序
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区。 数据库故障: 数据库文件丢失,主要涉及3个数据库,数千张表。数据库文件丢失原因未知,不能确定丢失的数据库文件的存放位置。数据库文件丢失后,服务器仍处于开机状态,所幸未写入大量数据。
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例

推荐镜像

更多
http://www.vxiaotou.com