MySQL之函数

1、日期函数

获取年月日

select current_date();
在这里插入图片描述

获取时分秒

select current_time();
在这里插入图片描述

获取时间戳

select current_timestamp();
在这里插入图片描述

在日期的基础上加日期

select date_add('2019-7-10',interval 10 day);
在这里插入图片描述

在日期的基础上减去时间

select date_sub('2019-7-10',interval 2 day);
在这里插入图片描述

计算两个日期之间相差多少天

select datediff('2019-7-10','2019-4-12');
在这里插入图片描述

案例:
  • 创建一个留言表
mysql> create table msg(
    -> id int primary key auto_increment,
    -> content varchar(30) not null,
    -> sendtime datetime
    -> );
Query OK, 0 rows affected (0.04 sec)
  • 插入数据
mysql> insert into msg(content,sendtime) values('hello1',now());
Query OK, 1 row affected (0.00 sec)
mysql> insert into msg(content,sendtime) values('hello2',now());
Query OK, 1 row affected (0.00 sec)

mysql> select * from msg;
+----+---------+---------------------+
| id | content | sendtime            |
+----+---------+---------------------+
|  1 | hello1  | 2019-07-10 11:38:56 |
|  2 | hello2  | 2019-07-10 11:39:48 |
+----+---------+---------------------+
2 rows in set (0.00 sec)
  • 显示所有留言信息,发布日期只显示日期,不显示时间
mysql> select content,date(sendtime) from msg;

在这里插入图片描述

  • 请查询在两分钟内发布的帖子
 select * from msg where date_add(sendtime,interval 2 minute) > now();

2、字符串函数

在这里插入图片描述

案例:
  • 获取emp表的ename列的字符集
mysql> select charset(ename) from emp;

在这里插入图片描述

  • 要求显示student表中的信息,显示格式:“xxx的语文是xxx分,数学xxx分,英语xxx分”
mysql> select concat(name,'的语文是',yuwen,'分,数学是',shuxue,'分,英语是',yingyu,'分') as '分数' from exam_result;

在这里插入图片描述

  • 求学生表中学生姓名占用的字节数
mysql> select length(name) ,name from exam_result;

在这里插入图片描述

  • 将emp表中所有名字中有S的替换成’上海’
select replace(ename,'S','上海'),ename from emp;

在这里插入图片描述

  • 截取emp表中ename字段的第二个到第三个字符
mysql> select substring(ename,2,2),ename from emp;

在这里插入图片描述

  • 以首字母小写的方式显示所有员工的姓名
mysql> select concat(lcase(substring(ename,1,1)),substring(ename,2)) as name from emp;

在这里插入图片描述

  • 查找字符串’10,A,B’中逗号’,'出现的次数cnt
select length('10,A,B') - length(replace('10,A,B',',','')) as cnt;

在这里插入图片描述

3、数学函数

在这里插入图片描述

  • 绝对值
mysql> select abs(-100.2);

在这里插入图片描述

  • 向上取整
select ceiling(23.04);

在这里插入图片描述

  • 向下取整
select floor(23.04);

在这里插入图片描述

  • 保留2位小数位数(小数四舍五入)
mysql> select format(12.3456,2);

在这里插入图片描述

  • 产生随机数
select rand();

在这里插入图片描述

其他函数

user()查询当前用户
mysql> select user();
md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串
mysql> select md5('admin');

在这里插入图片描述

database()显示当前正在使用的数据库
mysql> select database();
password()函数,MySQL数据库使用该函数对用户加密
mysql> select password('root');

在这里插入图片描述

ifnull(val1,val2)如果val1为null,返回val2,否则返回val1的值
mysql> select ifnull('abc','123');
mysql> select ifnull(null,'123');

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值