MySQL编程:关键函数深度剖析——日期、字符串、数学等全掌握

MySQL编程:核心函数深度剖析——日期、字符串、数学等全面解读

目录

  1. 函数
    1.1 日期函数
    1.2 字符串函数
    1.3 数学函数
    1.4 其他函数

1. 函数

1.1 日期函数

日期函数相关图片

  • 获取当前日期
mysql> select current_date();
+----------------+
| current_date() |
+----------------+
| 2024-09-17     |
+----------------+
1 row in set (0.00 sec)
  • 获取当前时间
mysql> select current_time();
+----------------+
| current_time() |
+----------------+
| 21:37:52       |
+----------------+
1 row in set (0.00 sec)
  • 获取当前时间戳(包含日期和时间)
mysql> select current_timestamp();
+---------------------+
| current_timestamp() |
+---------------------+
| 2024-09-17 21:39:02 |
+---------------------+
1 row in set (0.00 sec)
  • 获取当前日期和时间
mysql> select now();
+---------------------+
| now()               |
+---------------------+
| 2024-09-17 21:44:10 |
+---------------------+
1 row in set (0.00 sec)
  • 在日期基础上添加时间
# 添加10天
mysql> select date_add('2022-01-1',interval 10 day);
+---------------------------------------+
| date_add('2022-01-1',interval 10 day) |
+---------------------------------------+
| 2022-01-11                            |
+---------------------------------------+
1 row in set (0.00 sec)

# 添加10分钟
mysql> select date_add('2022-01-1',interval 10 minute);
+------------------------------------------+
| date_add('2022-01-1',interval 10 minute) |
+------------------------------------------+
| 2022-01-01 00:10:00                      |
+------------------------------------------+
1 row in set (0.00 sec)

# 添加10秒
mysql> select date_add('2022-01-1',interval 10 second);
+------------------------------------------+
| date_add('2022-01-1',interval 10 second) |
+------------------------------------------+
| 2022-01-01 00:00:10                      |
+------------------------------------------+
1 row in set (0.00 sec)
  • 在日期基础上减去时间
# 减去15天
mysql> select date_sub('2023-10-12',interval 15 day);
+----------------------------------------+
| date_sub('2023-10-12',interval 15 day) |
+----------------------------------------+
| 2023-09-27                             |
+----------------------------------------+
1 row in set (0.00 sec)

# 减去15分钟
mysql> select date_sub('2023-10-12',interval 15 minute);
+-------------------------------------------+
| date_sub('2023-10-12',interval 15 minute) |
+-------------------------------------------+
| 2023-10-11 23:45:00                       |
+-------------------------------------------+
1 row in set (0.00 sec)

# 减去15秒
mysql> select date_sub('2023-10-12',interval 15 second);
+-------------------------------------------+
| date_sub('2023-10-12',interval 15 second) |
+-------------------------------------------+
| 2023-10-11 23:59:45                       |
+-------------------------------------------+
1 row in set (0.00 sec)
  • 计算两个日期之间的天数差(前者减后者)
mysql> select datediff('2023-10-15','2023-9-8');
+-----------------------------------+
| datediff('2023-10-15','2023-9-8') |
+-----------------------------------+
|                                37 |
+-----------------------------------+
1 row in set (0.00 sec)

mysql> select datediff('2023-9-8','2023-10-15');
+-----------------------------------+
| datediff('2023-9-8','2023-10-15') |
+-----------------------------------+
|                               -37 |
+-----------------------------------+
1 row in set (0.00 sec)

案例-1

  • 创建记录生日的表:
mysql> create table tmp(
    -> id int primary key auto_increment,
    -> birthday date);
Query OK, 0 rows affected (0.03 sec)

mysql> desc tmp;
+----------+---------+------+-----+---------+----------------+
| Field    | Type    | Null | Key | Default | Extra          |
+----------+---------+------+-----+---------+----------------+
| id       | int(11) | NO   | PRI | NULL    | auto_increment |
| birthday | date    | YES  |     | NULL    |                |
+----------+---------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
  • 插入当前日期:
mysql> insert into tmp (birthday) values(current_date());
Query OK, 1 row affected (0.01 sec)

mysql> select * from tmp;
+----+------------+
| id | birthday   |
+----+------------+
|  1 | 2024-09-17 |
+----+------------+
1 row in set (0.00 sec)

案例-2

  • 创建留言表:
mysql> create table msg(
    -> id int primary key auto_increment,
    -> content varchar(30) not null,
    -> sendtime datetime);
Query OK, 0 rows affected (0.02 sec)

mysql> desc msg;
+----------+-------------+------+-----+---------+----------------+
| Field    | Type        | Null | Key | Default | Extra          |
+----------+-------------+------+-----+---------+----------------+
| id       | int(11)     | NO   | PRI | NULL    | auto_increment |
| content  | varchar(30) | NO   |     | NULL    |                |
| sendtime | datetime    | YES  |     | NULL    |                |
+----------+-------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)
  • 插入数据:
mysql> insert into msg (content,sendtime) values('hello mysql',now());
Query OK, 1 row affected (0.01 sec)

mysql> insert into msg (content,sendtime) values('hello friend',now());
Query OK, 1 row affected (0.01 sec)

mysql> select * from msg;
+----+--------------+---------------------+
| id | content      | sendtime            |
+----+--------------+---------------------+
|  1 | hello mysql  | 2024-09-17 21:50:49 |
|  2 | hello friend | 2024-09-17 21:50:56 |
+----+--------------+---------------------+
2 rows in set (0.00 sec)
  • 显示留言信息,仅显示日期部分:
mysql> select content,date(sendtime) from msg;
+--------------+----------------+
| content      | date(sendtime) |
+--------------+----------------+
| hello mysql  | 2024-09-17     |
| hello friend | 2024-09-17     |
+--------------+----------------+
2 rows in set (0.00 sec)
  • 查询两分钟内发布的帖子:
# 直接查询两分钟内发布的帖子(已过两分钟无结果)
mysql> select * from msg where date_add(sendtime,interval 2 minute) > now();
Empty set (0.00 sec)

# 插入新数据后查询
mysql> insert into msg (content,sendtime) values('excuse me',now());
Query OK, 1 row affected (0.01 sec)

mysql> select * from msg where date_add(sendtime,interval 2 minute) > now();
+----+-----------+---------------------+
| id | content   | sendtime            |
+----+-----------+---------------------+
|  3 | excuse me | 2024-09-17 21:55:52 |
+----+-----------+---------------------+
1 row in set (0.00 sec)

1.2 字符串函数

字符串函数相关图片

  • 获取字符串字符集
mysql> select charset('aaa');
+----------------+
| charset('aaa') |
+----------------+
| utf8           |
+----------------+
1 row in set (0.00 sec)
  • 获取表中某列的字符集
mysql> select charset(ename) from emp;
+----------------+
| charset(ename) |
+----------------+
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
| utf8           |
+----------------+
14 rows in set (0.00 sec)
  • 连接字符串
mysql> select concat('abc','123',456);
+-------------------------+
| concat('abc','123',456) |
+-------------------------+
| abc123456               |
+-------------------------+
1 row in set (0.00 sec)
  • 格式化表中信息显示
mysql> select concat(name,'的语文是',chinese,'分,数学是',math,'分') from exam_result;
+------------------------------------------------------------------+
| concat(name,'的语文是',chinese,'分,数学是',math,'分')           |
+------------------------------------------------------------------+
| 唐三藏的语文是134分,数学是98分                                  |
| 猪悟能的语文是176分,数学是98分                                  |
| 曹孟德的语文是140分,数学是90分                                  |
| 刘玄德的语文是110分,数学是115分                                 |
| 孙权的语文是140分,数学是73分                                    |
| 宋公明的语文是150分,数学是95分                                  |
+------------------------------------------------------------------+
6 rows in set (0.00 sec)
  • 获取字符串占用字节数
# 中文utf8编码占3字节,英文数字占1字节
mysql> select name,length(name) from student;
+--------+--------------+
| name   | length(name) |
+--------+--------------+
| 张三   |            6 |
| 李四   |            6 |
| 王五   |            6 |
| 孙权   |            6 |
| 妲己   |            6 |
+--------+--------------+
5 rows in set (0.00 sec)

mysql> select length('abcd中');
+-------------------+
| length('abcd中')  |
+-------------------+
|                 7 |
+-------------------+
1 row in set (0.00 sec)
  • 判断子串是否在主串中
mysql> select instr('abcdef123','123a') bool;
+------+
| bool |
+------+
|    0 |
+------+
1 row in set (0.00 sec)

mysql> select instr('abcdef123','123') bool;
+------+
| bool |
+------+
|    7 |
+------+
1 row in set (0.00 sec)
  • 转换字符串大小写
# 转大写
mysql> select ucase('abcdef') res;
+--------+
| res    |
+--------+
| ABCDEF |
+--------+
1 row in set (0.00 sec)

# 转小写
mysql> select lcase('ABCDEF') res;
+--------+
| res    |
+--------+
| abcdef |
+--------+
1 row in set (0.00 sec)
  • 截取字符串
# 从左边取3个字符
mysql> select left('abcdef',3);
+------------------+
| left('abcdef',3) |
+------------------+
| abc              |
+------------------+
1 row in set (0.00 sec)

# 从右边取3个字符
mysql> select right('abcdef',3);
+-------------------+
| right('abcdef',3) |
+-------------------+
| def               |
+-------------------+
1 row in set (0.00 sec)
  • 替换字符串中的特定内容
mysql> select replace(ename,'S','上海') from emp;
+-----------------------------+
| replace(ename,'S','上海')   |
+-----------------------------+
| 上海MITH                    |
| ALLEN                       |
| WARD                        |
| JONE上海                    |
| MARTIN                      |
| BLAKE                       |
| CLARK                       |
| 上海COTT                    |
| KING                        |
| TURNER                      |
| ADAM上海                    |
| JAME上海                    |
| FORD                        |
| MILLER                      |
+-----------------------------+
14 rows in set (0.00 sec)
  • 截取指定范围的字符串
mysql> select substring(ename,2,2) from emp;
+----------------------+
| substring(ename,2,2) |
+----------------------+
| MI                   |
| LL                   |
| AR                   |
| ON                   |
| AR                   |
| LA                   |
| LA                   |
| CO                   |
| IN                   |
| UR                   |
| DA                   |
| AM                   |
| OR                   |
| IL                   |
+----------------------+
14 rows in set (0.00 sec)
  • 首字母小写显示姓名
mysql> select concat(lcase(substring(ename,1,1)),substring(ename,2)) from emp;
+--------------------------------------------------------+
| concat(lcase(substring(ename,1,1)),substring(ename,2)) |
+--------------------------------------------------------+
| sMITH                                                  |
| aLLEN                                                  |
| wARD                                                   |
| jONES                                                  |
| mARTIN                                                 |
| bLAKE                                                  |
| cLARK                                                  |
| sCOTT                                                  |
| kING                                                   |
| tURNER                                                 |
| aDAMS                                                  |
| jAMES                                                  |
| fORD                                                   |
| mILLER                                                 |
+--------------------------------------------------------+
14 rows in set (0.00 sec)
  • 去除字符串前后空格
# 去除前空格
mysql> select ltrim('   nihao           ') res;
+------------------+
| res              |
+------------------+
| nihao            |
+------------------+
1 row in set (0.00 sec)

# 去除后空格
mysql> select rtrim('   nihao           ') res;
+----------+
| res      |
+----------+
|    nihao |
+----------+
1 row in set (0.00 sec)

# 去除前后空格
mysql> select trim('   nihao           ') res;
+-------+
| res   |
+-------+
| nihao |
+-------+
1 row in set (0.00 sec)

1.3 数学函数

数学函数相关图片

  • 绝对值

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12961.html

(0)
LomuLomu
上一篇 13小时前
下一篇 8小时前

相关推荐

  • Python打造萌趣招财猫图像

    文章标题: 用Python构建俏皮招财猫图像 文章内容:🌟欢迎光临我的个人主页点击查看 🌟盼望您的支持三连 🌟 🌟欢迎来我的个人主页访问 🌟期望您的关注三连 🌟 🌟个人主页欢迎你来逛 🌟期待你的互动三连🌟 ​​​​​ ​​​​​​​​​ ​​​​ 招财猫,又叫做“幸运猫”,是代表财富与好运的一种吉祥物,常出现在亚洲文化里的商店、餐厅和家庭中。今日,我将带您借…

    2025 年 7 月 9 日
    3800
  • 【GreatSQL优化器-10】find_best_ref

    【GreatSQL优化器-10】find_best_ref 一、find_best_ref介绍 GreatSQL的优化器对于join的表需要根据行数和cost来确定最后哪张表先执行哪张表后执行,这里面就涉及到预估满足条件的表数据,在keyuse_array数组有值的情况下,会用find_best_ref函数来通过索引进行cost和rows的估计,并且会找出最…

    2025 年 1 月 16 日
    35500
  • JavaScript模块化发展:CommonJS到ES Module的深度剖析

    文章标题: JavaScript模块化发展:从CommonJS到ES模块的全面解读 文章内容:#### 文章目录 一、模块化的背景与发展历程 1.1 为何需要模块化? 1.2 模块化发展时间线 二、CommonJS规范 2.1 核心特性 2.2 基础语法 2.3 实现原理 2.4 特点剖析 三、AMD(异步模块定义) 3.1 设计背景 3.2 核心语法 3.…

    2025 年 7 月 9 日
    5000
  • 2025年最新IDEA激活码永久破解教程:支持JetBrains全家桶2099年授权

    前言 本教程适用于JetBrains全系列开发工具,包括但不限于IDEA、PyCharm、DataGrip、Goland等。下面先展示最新IDEA版本成功破解至2099年的效果图: 接下来,我将通过详细的图文步骤,教大家如何将IDEA永久激活至2099年。这个方法同样适用于旧版本,无论您使用什么操作系统或版本,本教程都能完美适配。 第一步:获取IDEA安装包…

    IDEA破解教程 6天前
    17200
  • JavaAI智能治理:代码从无序到规范的蜕变

    文章标题: JavaAI智能治理:代码从无序到规范的华丽转身 文章内容: 文章目录 一、前言 二、飞算JavaAI平台 三、飞算JavaAI安装流程 3.1 Idea安装配置 3.2 官网注册登入 四、飞算JavaAI独特魅力:合并项目场景 4.1 ERP老项目精准焕新:保留核心逻辑的智能改造之道 4.2 智能合并:破解ERP系统代码迷宫的密钥 4.3 ER…

    2天前
    1400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信