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