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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
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;

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
49 3
|
1月前
|
SQL 关系型数据库 MySQL
案例剖析:MySQL唯一索引并发插入导致死锁!
案例剖析:MySQL唯一索引并发插入导致死锁!
案例剖析:MySQL唯一索引并发插入导致死锁!
|
1月前
|
SQL 关系型数据库 MySQL
案例剖析,MySQL共享锁引发的死锁问题!
案例剖析,MySQL共享锁引发的死锁问题!
|
1月前
|
消息中间件 关系型数据库 MySQL
大数据-117 - Flink DataStream Sink 案例:写出到MySQL、写出到Kafka
大数据-117 - Flink DataStream Sink 案例:写出到MySQL、写出到Kafka
135 0
|
23天前
|
关系型数据库 MySQL 数据库
一个 MySQL 数据库死锁的案例和解决方案
本文介绍了一个 MySQL 数据库死锁的案例和解决方案。
39 3
|
26天前
|
存储 关系型数据库 MySQL
基于案例分析 MySQL 权限认证中的具体优先原则
【10月更文挑战第26天】本文通过具体案例分析了MySQL权限认证中的优先原则,包括全局权限、数据库级别权限和表级别权限的设置与优先级。全局权限优先于数据库级别权限,后者又优先于表级别权限。在权限冲突时,更严格的权限将被优先执行,确保数据库的安全性与资源合理分配。
|
2月前
|
SQL 关系型数据库 MySQL
Python操作pymysql数据库的流程与技巧
在现代软件开发中,Python作为一门高效且易于学习的编程语言,广泛应用于各种场景,其中包括数据库操作。**PyMySQL** 是一个流行的Python数据库接口,用于连接和操作MySQL数据库。它提供了一种简便的方法来执行SQL语句、处理数据和管理数据库事务。以下是使用PyMySQL操作MySQL数据库的流程与技巧,旨在为开发者提供一个清晰、实用的指南。
54 0
|
2月前
|
SQL 关系型数据库 MySQL
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
173 0
|
8天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
23 1
|
10天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
25 4