首页 > 数据库 >Mysql基础6-常用数据库函数

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

时间:2023-07-18 23:12:45浏览次数:34  
标签:set 函数 数据库 Mysql sec mysql 0.00 select row

一、字符串函数

  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,...) 函数

mysql> select concat("hello","world");
+-------------------------+
| concat("hello","world") |
+-------------------------+
| helloworld              |
+-------------------------+
1 row in set (0.00 sec)

    示例2:lower(str)

mysql> select lower("Hello");
+----------------+
| lower("Hello") |
+----------------+
| hello          |
+----------------+
1 row in set (0.00 sec)

    示例3:upper(str)

mysql> select upper("Hello");
+----------------+
| upper("Hello") |
+----------------+
| HELLO          |
+----------------+
1 row in set (0.00 sec)

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

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

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

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

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

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

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

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

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)

mysql> select trim(" Hello world ");
+-----------------------+
| trim(" Hello world ") |
+-----------------------+
| Hello world           |
+-----------------------+
1 row in set (0.00 sec)

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

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

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数据

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)

    修改后的数据

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):向上取整

mysql> select ceil(1.1);
+-----------+
| ceil(1.1) |
+-----------+
|         2 |
+-----------+
1 row in set (0.00 sec)

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

mysql> select floor(1.9);
+------------+
| floor(1.9) |
+------------+
|          1 |
+------------+
1 row in set (0.00 sec)

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

mysql> select mod(5,2);
+----------+
| mod(5,2) |
+----------+
|        1 |
+----------+
1 row in set (0.00 sec)

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

mysql> select rand();
+---------------------+
| rand()              |
+---------------------+
| 0.20385351237268515 |
+---------------------+
1 row in set (0.00 sec)

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

mysql> select round(3.1415926,2);
+--------------------+
| round(3.1415926,2) |
+--------------------+
|               3.14 |
+--------------------+
1 row in set (0.00 sec)

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

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():返回当前日期

mysql> select curdate();
+------------+
| curdate()  |
+------------+
| 2023-07-18 |
+------------+
1 row in set (0.00 sec)

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

mysql> select curtime();
+-----------+
| curtime() |
+-----------+
| 21:52:43  |
+-----------+
1 row in set (0.00 sec)

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

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

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

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的月份

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的日期

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后的时间值

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之间的天数

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

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

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表原始数据

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)
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)原始数据

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)
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)

 

标签:set,函数,数据库,Mysql,sec,mysql,0.00,select,row
From: https://www.cnblogs.com/Se7eN-HOU/p/17564376.html

相关文章

  • MySQL
    SQLSQL通用语法SQL语句可以单行或多行书写,以分号结尾。SQL语句可以使用空格/缩进来增强语句可读性。MySQL数据库的SQL语句不区分大小写,关键字建议使用大写。注释单行注释:--注释内容或者#注释内容(MySQL特有)多行注释:/*注释内容*/ DDL-数据库操作查询......
  • 色彩解锁:探索革命性的CSS color()函数和新的色彩空间
    Google在6月份发布了一篇新博客,介绍了CSS中的新颜色空间和函数,支持所有主流引擎。下面是文章的链接:NewCSScolorspacesandfunctionsinallmajorengineshttps://web.dev/color-spaces-and-functions/?ref=sidebar该文章展示了一些支持的色彩空间的例子。color()函数介绍:color......
  • coc仓库--minicap截图函数
    minicap截图1.原函数voidscreenShot(conststd::string*ADB_IP,cv::Mat*mat){//首先,运行runShellAndReturn获取file指针std::stringcmd="adb-s"+*ADB_IP+"shellLD_LIBRARY_PATH=/data/local/tmp/data/local/tmp/minicap-P1920x1080@1920x1......
  • MySQL高级锁之意向锁
    2.1意向锁2.1.1意向锁的概念意向锁的存在是为了协调行锁和表锁的关系,用于优化InnoDB加锁的策略。意向锁的主要功能就是:避免为了判断表是否存在行锁而去全表扫描。意向锁是由InnoDB在操作数据之前自动加的,不需要用户干预;意向共享锁(IS锁):事务在请求S锁前,要先获得IS锁意向排他锁(IX锁......
  • MySQL高级锁之临键锁
    2.4临键锁2.4.1临键锁的区间测试临键锁(Next-KeyLock):临键锁是查询时InnoDB根据查询的条件而锁定的一个范围,这个范围中包含有间隙锁和记录数;临键锁=间隙锁+记录锁。其设计的目的是为了解决PhantomProblem(幻读);主要是阻塞insert,但由于临键锁中包含有记录锁,因此临键锁所锁定的范......
  • MySQL高级锁之自增锁
    2.5自增锁MySQL的自增锁是指在使用自增主键(AutoIncrement)时,为了保证==唯一性和正确性==,系统会对自增字段进行加锁。这样可以确保同时插入多条记录时,每条记录都能够获得唯一的自增值。创建测试表:droptableifexistst3;CREATETABLE`t3`(`id`int(11)NOTNULLAUTO_INC......
  • PyMySQL插入字典类型的数据
    importpymysqlMYSQL_CONFIG={'host':'localhost',#IP地址'port':3306,#端口'user':'root',#用户名'passwd':'123456',#密码'db':'layui',......
  • Ubuntu安装MySQL、nginx、nacos
    Ubuntu安装mysql1、安装mysql#此命令直接安装最新版mysql8.0sudoapt-getinstallmysql-server2、查看默认用户及密码cat/etc/mysql/debian.cnfuser =debian-sys-maintpassword =s8hjWltF0W2EBU323、登录该用户mysql-udebian-sys-maint-pusemysql;updateuse......
  • Java中的split( )函数
      Java中的split()函数Leaf_Ysm关注IP属地:浙江0.1512018.10.2410:44:46字数252阅读46,821首先,我们来了解一下split()函数各个参数的意义publicString[]split(Stringregex,intlimit)regex--正则表达式分隔符。limit--分割的份数。下面就让我......
  • ORACLE数据库启停、闪回和锁表查询以及创建DBLINK
    数据库启动和停止停止orcale/oracle7//停止1.ps-ef|grepsmon2.exportORACLE_SID=cbsdba(cbsdba是实例名)3.sqlplus/assysdba 4.shutdown immediate;启动1.ps-ef|grepsmon2.exportORACLE_SID=cbsdba3.sqlplus/assysdba 4.startup;5.alter pluggabledatabas......