MySQL中常见函数

一、日期函数

1、NOW()   返回当前日期和时间

mysql> SELECT NOW();
+---------------------+
| NOW()               |
+---------------------+
| 2019-10-19 10:55:28 |
+---------------------+
1 row in set (0.00 sec)

2、DATE_FORMAT(d,f)   按表达式 f的要求显示日期 d

mysql> SELECT DATE_FORMAT(NOW(),‘%Y年-%m月-%d日 %H时:%i分:%s秒‘);
+----------------------------------------------------+
| DATE_FORMAT(NOW(),‘%Y年-%m月-%d日 %H时:%i分:%s秒‘) |
+----------------------------------------------------+
| 2019年-10月-19日 11时:03分:01秒                    |
+----------------------------------------------------+
1 row in set (0.00 sec)

3、DATE_ADD(d,INTERVAL expr type)   计算起始日期 d 加上一个时间段后的日期

mysql> SELECT DATE_ADD(NOW(),INTERVAL 1 DAY);
+--------------------------------+
| DATE_ADD(NOW(),INTERVAL 1 DAY) |
+--------------------------------+
| 2019-10-20 11:07:47            |
+--------------------------------+
1 row in set (0.00 sec)

注意:\expr:正数(加)、负数(减)
          \unit:支持毫秒microsecond、秒second、小时hour、天day、周week、年year

二、字符串函数

1、CONCAT(s1,s2...sn)   字符串 s1,s2 等多个字符串合并为一个字符串

mysql> SELECT CONCAT(‘My‘,‘SQL‘);
+--------------------+
| CONCAT(‘My‘,‘SQL‘) |
+--------------------+
| MySQL              |
+--------------------+
1 row in set (0.00 sec)

2、FIELD(s,s1,s2...)   返回第一个字符串 s 在字符串列表(s1,s2...)中的位置

mysql> SELECT FIELD(‘C‘,‘A‘,‘B‘,‘C‘,‘D‘);
+----------------------------+
| FIELD(‘C‘,‘A‘,‘B‘,‘C‘,‘D‘) |
+----------------------------+
|                          3 |
+----------------------------+
1 row in set (0.00 sec)

3、LOWER(s)   将字符串 s 的所有字母变成小写字母

mysql> SELECT LOWER(‘ABCD‘);
+---------------+
| LOWER(‘ABCD‘) |
+---------------+
| abcd          |
+---------------+
1 row in set (0.00 sec)

4、REVERSE(s)  将字符串s的顺序反过来

mysql> SELECT REVERSE(‘ABCD‘);
+-----------------+
| REVERSE(‘ABCD‘) |
+-----------------+
| DCBA            |
+-----------------+
1 row in set (0.00 sec)

三、数字函数

1、ABS(x)   返回 x 的绝对值

mysql> SELECT ABS(-10);
+----------+
| ABS(-10) |
+----------+
|       10 |
+----------+
1 row in set (0.00 sec)

2、ROUND(x)  返回离 x 最近的整数

mysql> SELECT ROUND(1.2345);
+---------------+
| ROUND(1.2345) |
+---------------+
|             1 |
+---------------+
1 row in set (0.00 sec)

3、RAND()  返回 0 到 1 的随机数

mysql> SELECT RAND();
+--------------------+
| RAND()             |
+--------------------+
| 0.5442781900468079 |
+--------------------+
1 row in set (0.00 sec)

4、POW(x,y)  返回 x 的 y 次方

mysql> SELECT POW(4,2);  #4的2次方
+----------+
| POW(4,2) |
+----------+
|       16 |
+----------+
1 row in set (0.00 sec)

四、聚合函数

1、AVG(expression)   返回一个表达式的平均值,expression 是一个字段

#返回 Products 表中Price 字段的平均值
mysql> SELECT AVG(price) AS AveragePrice FROM Products; 

2、COUNT(expression)   返回查询的记录总数,expression 参数是一个字段或者 * 号

#返回 Products 表中 products 字段总共有多少条记录:
mysql> SELECT COUNT(id) AS NumberOfProducts FROM Products;

3、MAX(expression)   返回字段 expression 中的最大值

#返回数据表 Products 中字段 Price 的最大值:
mysql> SELECT MAX(Price) AS LargestPrice FROM Products;

4、MIN(expression)   返回字段 expression 中的最小值

#返回数据表 Products 中字段 Price 的最小值:
mysql> SELECT MIN(Price) AS SmalltPrice FROM Products;

5、SUM(expression)  返回指定字段的总和

#计算 Products表中字段 Cost的总和:
mysql> SELECT SUM(Cost) AS TotalCost FROM Products;

6、group_concat(expression) 返回指定字段内容的拼接

mysql> SELECT GROUP_CONCAT(name) from crm_product;
+-----------------------+
| GROUP_CONCAT(name)    |
+-----------------------+
| 磷酸铁锂电池,叠片电池 |
+-----------------------+
1 row in set (0.00 sec)

原文地址:https://www.cnblogs.com/shenjianping/p/11703252.html

时间: 2024-08-06 00:09:17

MySQL中常见函数的相关文章

【个人笔记】《知了堂》MySQL中的数据类型

MySQL中的数据类型 1.整型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节  范围(-128~127) smallint(m) 2个字节  范围(-32768~32767) mediumint(m) 3个字节  范围(-8388608~8388607) int(m) 4个字节  范围(-2147483648~2147483647) bigint(m) 8个字节  范围(+-9.22*10的18次方) 取值范围如果加了unsigned,则最大值翻倍,如tinyint un

mysql中int、bigint、smallint和tinyint的区别与长度

对比发现 int bigint smallint 和 tinyint 类型,如果创建新表时没有指定 int(M) 中的M时,默认分别是 : int             -------     int(11) bigint       -------     bigint(20) smallint   -------     smallint(6) tinyint     -------     tinyint(4) 下面是这几种类型的取值范围 参考:http://www.2cto.com/d

mysql中计算两个日期的时间差函数TIMESTAMPDIFF用法

mysql中计算两个日期的时间差函数TIMESTAMPDIFF用法: 语法: TIMESTAMPDIFF(interval,datetime_expr1,datetime_expr2) 说明: 返回日期或日期时间表达式datetime_expr1 和datetime_expr2the 之间的整数差.其结果的单位由interval 参数给出.interval 的法定值同TIMESTAMPADD()函数说明中所列出的相同. mysql> SELECT TIMESTAMPDIFF(MONTH,'200

SQL-GROUP BY语句在MySQL中的一个错误使用被兼容的情况

首先创建数据库hncu,建立stud表格. 添加数据: create table stud( sno varchar(30) not null primary key, sname varchar(30) not null, age int, saddress varchar(30) ); INSERT INTO stud VALUES('1001','Tom',22,'湖南益阳'); INSERT INTO stud VALUES('1002','Jack',23,'益阳'); INSERT

MYSQL中存储过程的创建,调用及语法

MySQL 存储过程是从 MySQL 5.0 开始增加的新功能.存储过程的优点有一箩筐.不过最主要的还是执行效率和SQL 代码封装.特别是 SQL 代码封装功能,如果没有存储过程,在外部程序访问数据库时(例如 PHP),要组织很多 SQL 语句.特别是业务逻辑复杂的时候,一大堆的 SQL 和条件夹杂在 PHP 代码中,让人不寒而栗.现在有了 MySQL 存储过程,业务逻辑可以封装存储过程中,这样不仅容易维护,而且执行效率也高. 第一部分:创建一个简单的无参的存储过程 1 用mysql客户端登入

在Mysql中如何显示所有用户?

在Mysql中如何显示所有用户? 这是一个mysql初学者经常问到的一个问题,今天我们就带大家看看是如何在Mysql中显示所有用户的.通常我们在mysql中使用SHOW DATABASES可以显示所有的数据库,SHOW TABLES将会显示所有的数据表,那么你是不是会猜测显示所有用户的命令是SHOW USERS呢?不不不,并不是的,现在让我们一起来看看如何显示所有用户吧. 在Mysql中显示所有用户 1.登录数据库 首先,你需要使用如下命令登录到数据库,注意,必须是root用户哦~ ## mys

mysql中bigint、int、mediumint、smallint 和 tinyint的取值范

mysql数据库设计,其中,对于数据性能优化,字段类型考虑很重要,搜集了些资料,整理分享出来,这篇为有关mysql整型bigint.int.mediumint.smallint 和 tinyint的语法介绍,如下:1.bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字),无符号的范围是0到 18446744073709551615.一位为 8 个字节. 2.int 一个正常大小整数.有符号

在MySQL中使用正则表达式

在MySQL中的REGEXP函数可以在平时使用SQL时匹配正则表达式,在平时在使用一些查询条件时可以使用REGEXP函数来匹配相应的字符从而可以替代很多自己不太熟悉或者是不了解的SQL函数且通用,从而提高日常的工作效率,在MySQL下的REGEXP函数使用十分简单,正则表达式的元字符可以参看:http://jim123.blog.51cto.com/4763600/1850919,REGEXP函数返回值是布尔值0和1,即,匹配为1,不配为0,如: mysql> SELECT 'Monty!' R

mysql中describe关键字

今天写代码的时候,有一个类的数据始终不能插入,老是提示在You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'describe, picPath1, picPath2, picPath3, picPath4, picPath5, agentId, belongStore' at li