前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql基础6-常用数据库函数

Mysql基础6-常用数据库函数

作者头像
Se7eN_HOU
发布2023-07-24 18:47:56
2850
发布2023-07-24 18:47:56
举报

一、字符串函数

  1、常见Mysql内置字符串函数
    • concat(s1,s2,s3,...):字符串拼接,将s1,s2,s3...等拼接成一个字符串
    • lower(str):将字符串str全部转为小写
    • upper(str):将字符串str全部转为大写
    • lpad(str,n,pad):左填充,将字符串pad对str的左边进行填充,达到n个字符串长度
    • rpad(str,n,pad):右填充,将字符串pad对str的右边进行填充,达到n个字符串长度
    • trim(str):去掉字符串头部和尾部的空格
    • substring(str,start,len):返回字符串str从start位置起的len长度的字符串 
  2、函数示例    

示例1:concat(s1,s2,s3,...) 函数

代码语言:javascript
复制
mysql> select concat("hello","world");
+-------------------------+
| concat("hello","world") |
+-------------------------+
| helloworld              |
+-------------------------+
1 row in set (0.00 sec)

示例2:lower(str)

代码语言:javascript
复制
mysql> select lower("Hello");
+----------------+
| lower("Hello") |
+----------------+
| hello          |
+----------------+
1 row in set (0.00 sec)

示例3:upper(str)

代码语言:javascript
复制
mysql> select upper("Hello");
+----------------+
| upper("Hello") |
+----------------+
| HELLO          |
+----------------+
1 row in set (0.00 sec)

示例4:lpad(str,n,pad)|

情况一:n小于原始字符串str的长度,只显示原始字符串的长度n的字符 

代码语言:javascript
复制
mysql> select lpad("张三",1,"靓仔");
+---------------------------+
| lpad("张三",1,"靓仔")     |
+---------------------------+
| 张                        |
+---------------------------+
1 row in set (0.00 sec)

情况二:当长度n大于str字符串的原始长度,小于拼接后的字符串长度后,显示原来的字符串str+pad继续补齐到n个字符串

代码语言:javascript
复制
mysql> select lpad("张三",3,"靓仔");
+---------------------------+
| lpad("张三",3,"靓仔")     |
+---------------------------+
| 靓张三                    |
+---------------------------+
1 row in set (0.00 sec)

情况三:如果n大于拼接后的字符串长度,会重复拼接pad字符串

代码语言:javascript
复制
mysql> select lpad("张三",6,"靓仔");
+---------------------------+
| lpad("张三",6,"靓仔")     |
+---------------------------+
| 靓仔靓仔张三              |
+---------------------------+
1 row in set (0.00 sec)

示例5:rpad(str,n,pad)

代码语言:javascript
复制
mysql> select rpad("张三",1,"靓仔");
+---------------------------+
| rpad("张三",1,"靓仔")     |
+---------------------------+
| 张                        |
+---------------------------+
1 row in set (0.00 sec)

mysql> select rpad("张三",3,"靓仔");
+---------------------------+
| rpad("张三",3,"靓仔")     |
+---------------------------+
| 张三靓                    |
+---------------------------+
1 row in set (0.00 sec)

mysql> select rpad("张三",6,"靓仔");
+---------------------------+
| rpad("张三",6,"靓仔")     |
+---------------------------+
| 张三靓仔靓仔              |
+---------------------------+
1 row in set (0.00 sec)

情况处理:同lpad情况

    示例6:trim(str)

代码语言:javascript
复制
mysql> select trim(" Hello world ");
+-----------------------+
| trim(" Hello world ") |
+-----------------------+
| Hello world           |
+-----------------------+
1 row in set (0.00 sec)

注意:trim只会取出开始和结尾的空格,不会去除中间的空格。

示例7:substring(str,start,len)

代码语言:javascript
复制
mysql> select substring("hello world", 1, 5);
+--------------------------------+
| substring("hello world", 1, 5) |
+--------------------------------+
| hello                          |
+--------------------------------+
1 row in set (0.00 sec)

注意:截取字符串的索引从1开始

示例8:在table_test中对id重新编号,统一显示五位数,不足五位数的前面补0

    原始表test数据

代码语言:javascript
复制
mysql> select * from test;
+------+---------+--------------+-----------+
| id   | stu_num | stu_name     | stu_score |
+------+---------+--------------+-----------+
|    1 | 1       | 张三         | 90        |
|    2 | 2       | 李四         | 87        |
|    3 | 3       | 王五         | 78        |
|    4 | 14      | 赵六         | 83        |
|    5 | 25      | 王二麻子     | 94        |
+------+---------+--------------+-----------+
5 rows in set (0.00 sec)

    修改后的数据

代码语言:javascript
复制
mysql> update test set stu_num = lpad(stu_num,5,'0');
Query OK, 5 rows affected (0.01 sec)
Rows matched: 5  Changed: 5  Warnings: 0

mysql> select * from test;
+------+---------+--------------+-----------+
| id   | stu_num | stu_name     | stu_score |
+------+---------+--------------+-----------+
|    1 | 00001   | 张三         | 90        |
|    2 | 00002   | 李四         | 87        |
|    3 | 00003   | 王五         | 78        |
|    4 | 00014   | 赵六         | 83        |
|    5 | 00025   | 王二麻子     | 94        |
+------+---------+--------------+-----------+
5 rows in set (0.00 sec)

二、数值函数

  1、常见数值函数
    • ceil(x):向上取整
    • floor(x):向下取整
    • mod(x,y):返回x/y的模
    • rand():返回0-1内的随机数
    • round(x,y):求参数x的四舍五入的值,保留y位小数
  2、函数示例

示例1:ceil(x):向上取整

代码语言:javascript
复制
mysql> select ceil(1.1);
+-----------+
| ceil(1.1) |
+-----------+
|         2 |
+-----------+
1 row in set (0.00 sec)

示例2:floor(x):向下取整

代码语言:javascript
复制
mysql> select floor(1.9);
+------------+
| floor(1.9) |
+------------+
|          1 |
+------------+
1 row in set (0.00 sec)

示例3:mod(x,y):返回x/y的模

代码语言:javascript
复制
mysql> select mod(5,2);
+----------+
| mod(5,2) |
+----------+
|        1 |
+----------+
1 row in set (0.00 sec)

示例4:rand():返回0-1内的随机数

代码语言:javascript
复制
mysql> select rand();
+---------------------+
| rand()              |
+---------------------+
| 0.20385351237268515 |
+---------------------+
1 row in set (0.00 sec)

示例5:round(x,y):求参数x的四舍五入的值,保留y位小数

代码语言:javascript
复制
mysql> select round(3.1415926,2);
+--------------------+
| round(3.1415926,2) |
+--------------------+
|               3.14 |
+--------------------+
1 row in set (0.00 sec)

示例6:综合案例:通过数据库函数,生成一个六位数的随机验证码

代码语言:javascript
复制
mysql> select rpad(round(rand()*1000000, 0),6,'0');
+--------------------------------------+
| rpad(round(rand()*1000000, 0),6,'0') |
+--------------------------------------+
| 192803                               |
+--------------------------------------+
1 row in set (0.00 sec)

说明:

      1、rand()生成的小数,乘以1000000,才有可能是有六位整数的小数,所以这个时候需要市容round()四舍五入取整数

      2、因为rand()生成的小数有可能是0.999999这样的乘以1000000就是6位整数,也有可能生成的小数是0.000009这样的小数就算乘以1000000也不够六位整数

      3、所以还需要使用rpad()函数,如果整数不足六位,就在后面补0

三、日期函数

  1、常见日期函数
    • curdate():返回当前日期
    • curtime():返回当前时间
    • now():返回当前日期和时间
    • year(date):获取指定date的年份
    • month(date):获取指定date的月份
    • day(date):获取指定date的日期
    • date_add(date,interval expr type):返回一个日期/时间值加上一个时间间隔expr后的时间值
    • datediff(date1,date2):返回起始时间date1和结束时间date2之间的天数
  2、函数示例

示例1:curdate():返回当前日期

代码语言:javascript
复制
mysql> select curdate();
+------------+
| curdate()  |
+------------+
| 2023-07-18 |
+------------+
1 row in set (0.00 sec)

示例2:curtime():返回当前时间

代码语言:javascript
复制
mysql> select curtime();
+-----------+
| curtime() |
+-----------+
| 21:52:43  |
+-----------+
1 row in set (0.00 sec)

示例3:now():返回当前日期和时间

代码语言:javascript
复制
mysql> select now();
+---------------------+
| now()               |
+---------------------+
| 2023-07-18 21:53:10 |
+---------------------+
1 row in set (0.00 sec)

示例4:year(date):获取指定date的年份

代码语言:javascript
复制
mysql> select year("2023-07-18 21:53:10");
+-----------------------------+
| year("2023-07-18 21:53:10") |
+-----------------------------+
|                        2023 |
+-----------------------------+
1 row in set (0.01 sec)

示例5:month(date):获取指定date的月份

代码语言:javascript
复制
mysql> select month("2023-07-18 21:53:10");
+------------------------------+
| month("2023-07-18 21:53:10") |
+------------------------------+
|                            7 |
+------------------------------+
1 row in set (0.00 sec)

示例6:day(date):获取指定date的日期

代码语言:javascript
复制
mysql> select day("2023-07-18 21:53:10");
+----------------------------+
| day("2023-07-18 21:53:10") |
+----------------------------+
|                         18 |
+----------------------------+
1 row in set (0.00 sec)

示例7:date_add(date,interval expr type):返回一个日期/时间值加上一个时间间隔expr后的时间值

代码语言:javascript
复制
mysql> select date_add("2023-07-18 21:53:10", interval 2 day);
+-------------------------------------------------+
| date_add("2023-07-18 21:53:10", interval 2 day) |
+-------------------------------------------------+
| 2023-07-20 21:53:10                             |
+-------------------------------------------------+
1 row in set (0.01 sec)

mysql> select date_add("2023-07-18 21:53:10", interval 2 month);
+---------------------------------------------------+
| date_add("2023-07-18 21:53:10", interval 2 month) |
+---------------------------------------------------+
| 2023-09-18 21:53:10                               |
+---------------------------------------------------+
1 row in set (0.00 sec)

mysql> select date_add("2023-07-18 21:53:10", interval 2 year);
+--------------------------------------------------+
| date_add("2023-07-18 21:53:10", interval 2 year) |
+--------------------------------------------------+
| 2025-07-18 21:53:10                              |
+--------------------------------------------------+
1 row in set (0.00 sec)

示例8:datediff(date1,date2):返回起始时间date1和结束时间date2之间的天数

代码语言:javascript
复制
mysql> select datediff("2023-07-18 21:53:10", "2023-07-28 21:53:10");
+--------------------------------------------------------+
| datediff("2023-07-18 21:53:10", "2023-07-28 21:53:10") |
+--------------------------------------------------------+
|                                                    -10 |
+--------------------------------------------------------+
1 row in set (0.00 sec)

mysql> select datediff("2023-07-28 21:53:10", "2023-07-18 21:53:10");
+--------------------------------------------------------+
| datediff("2023-07-28 21:53:10", "2023-07-18 21:53:10") |
+--------------------------------------------------------+
|                                                     10 |
+--------------------------------------------------------+
1 row in set (0.00 sec)

四、流程函数

  1、常见流程函数
    • if(value, t, f):如果value为true,则返回t,否则返回f
    • ifnull(value1,value2):如果value1不为空,返回value1,否则返回value2
    • case when [val1] then [res1]...else[default] end:如果val1为true,则返回res1,否则返回default默认值
    • case[expr] when [val1] then [res1]...else[default] end:如果expr的值等于val1,返回res1,否则返回默认值
  2、函数示例

示例1:if(value, t, f):如果value为true,则返回t,否则返回f

代码语言:javascript
复制
mysql> select if(1>2,"ok","no");
+-------------------+
| if(1>2,"ok","no") |
+-------------------+
| no                |
+-------------------+
1 row in set (0.00 sec)

示例2:ifnull(value1,value2):如果value1不为空,返回value1,否则返回value2

代码语言:javascript
复制
mysql> select ifnull("ok","default");
+------------------------+
| ifnull("ok","default") |
+------------------------+
| ok                     |
+------------------------+
1 row in set (0.00 sec)

mysql> select ifnull("","default");
+----------------------+
| ifnull("","default") |
+----------------------+
|                      |              注意:空字符串不是null
+----------------------+
1 row in set (0.00 sec)

mysql> select ifnull(null,"default");
+------------------------+
| ifnull(null,"default") |
+------------------------+
| default                |
+------------------------+
1 row in set (0.00 sec)

示例3:case  [expr] when [val1] then [res1]...else[default] end:如果val1为true,则返回res1,否则返回default默认值

    需求:在table_test中,展示姓名和特色一栏,特色根据address的值来设定,北京特色烤鸭,上海特色蟹黄包,西安特色肉夹馍,其他地方都是红烧肉

    table_test表原始数据

代码语言:javascript
复制
mysql> select * from table_test;
+------+--------+------+---------+
| id   | name   | age  | address |
+------+--------+------+---------+
|    1 | 刘一   |   18 | 西安    |
|    2 | 陈二   |   19 | 上海    |
|    3 | 张三   |   21 | 北京    |
|    4 | 李四   |   18 | 北京    |
|    5 | 王五   |   21 | 西安    |
|    6 | 赵六   |   22 | NULL    |
+------+--------+------+---------+
6 rows in set (0.00 sec)
代码语言:javascript
复制
mysql> select name ,(case address when "北京" then "烤鸭" when "上海" then "蟹黄包" when "西安" then "肉夹馍" else "红烧肉" end) as "特色" from table_test;
+--------+--------------+
| name   | 特色         |
+--------+--------------+
| 刘一   | 肉夹馍       |
| 陈二   | 蟹黄包       |
| 张三   | 烤鸭         |
| 李四   | 烤鸭         |
| 王五   | 肉夹馍       |
| 赵六   | 红烧肉       |
+--------+--------------+
6 rows in set (0.00 sec)

示例4:需求:在学生成绩表中,根据成绩展示优秀,良好一般。

    学生成绩表(test)原始数据

代码语言:javascript
复制
mysql> select * from test;
+------+---------+--------------+-----------+
| id   | stu_num | stu_name     | stu_score |
+------+---------+--------------+-----------+
|    1 | 00001   | 张三         | 90        |
|    2 | 00002   | 李四         | 87        |
|    3 | 00003   | 王五         | 78        |
|    4 | 00014   | 赵六         | 83        |
|    5 | 00025   | 王二麻子     | 94        |
+------+---------+--------------+-----------+
5 rows in set (0.00 sec)
代码语言:javascript
复制
mysql> select stu_name, (case when stu_score>=90 then "优秀" when stu_score >=80 then "良好" when stu_score >=70 then
"一般" when stu_score >=60 then "及格" else "不及格" end) as "成绩" from test;
+--------------+--------+
| stu_name     | 成绩   |
+--------------+--------+
| 张三         | 优秀   |
| 李四         | 良好   |
| 王五         | 一般   |
| 赵六         | 良好   |
| 王二麻子     | 优秀   |
+--------------+--------+
5 rows in set (0.00 sec)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-07-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、字符串函数
    •   1、常见Mysql内置字符串函数
      •   2、函数示例    
      • 二、数值函数
        •   1、常见数值函数
          •   2、函数示例
          • 三、日期函数
            •   1、常见日期函数
              •   2、函数示例
              • 四、流程函数
                •   1、常见流程函数
                  •   2、函数示例
                  相关产品与服务
                  云数据库 MySQL
                  腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档