搜索
首页数据库mysql教程 【MySQL 09】常用函数

【MySQL 09】常用函数

Feb 04, 2017 pm 01:25 PM

1、数学函数

  • ABS(x) 返回x的绝对值

  • BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制)

  • CEILING(x) 返回大于x的最小整数值

  • EXP(x) 返回值e(自然对数的底)的x次方

  • FLOOR(x) 返回小于x的最大整数值

  • GREATEST(x1,x2,…,xn)返回集合中最大的值

  • LEAST(x1,x2,…,xn) 返回集合中最小的值

  • LN(x) 返回x的自然对数 LOG(x,y)返回x的以y为底的对数

  • MOD(x,y) 返回x/y的模(余数) PI()返回pi的值(圆周率)

  • RAND()返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。

  • ROUND(x,y)返回参数x的四舍五入的有y位小数的值

  • SIGN(x) 返回代表数字x的符号的值

  • SQRT(x) 返回一个数的平方根

  • TRUNCATE(x,y) 返回数字x截短为y位小数的结果

2、聚集函数

  • AVG(col)返回指定列的平均值

  • MIN(col)返回指定列的最小值

  • MAX(col)返回指定列的最大值

  • SUM(col)返回指定列的所有值之和

  • GROUP_CONCAT(col) 返回由属于一组的列值连接组合而成的结果

3、字符串函数

  • ASCII(char)返回字符的ASCII码值 BIT_LENGTH(str)返回字符串的比特长度

  • CONCAT(s1,s2…,sn)将s1,s2…,sn连接成字符串

  • CONCAT_WS(sep,s1,s2…,sn)将s1,s2…,sn连接成字符串,并用sep字符间隔

  • INSERT(str,x,y,instr) 将字符串str从第x位置开始,y个字符长的子串替换为字符串instr,返回结果

  • FIND_IN_SET(str,list)分析逗号分隔的list列表,如果发现str,返回str在list中的位置

  • LCASE(str)或LOWER(str) 返回将字符串str中所有字符改变为小写后的结果

  • LEFT(str,x)返回字符串str中最左边的x个字符

  • LENGTH(s)返回字符串str中的字符数

  • LTRIM(str) 从字符串str中切掉开头的空格

  • POSITION(substr,str) 返回子串substr在字符串str中第一次出现的位置

  • QUOTE(str) 用反斜杠转义str中的单引号

  • REPEAT(str,srchstr,rplcstr)返回字符串str重复x次的结果

  • REVERSE(str) 返回颠倒字符串str的结果

  • RIGHT(str,x) 返回字符串str中最右边的x个字符

  • RTRIM(str) 返回字符串str尾部的空格

  • STRCMP(s1,s2)比较字符串s1和s2

  • TRIM(str)去除字符串首部和尾部的所有空格

  • UCASE(str)或UPPER(str) 返回将字符串str中所有字符转变为大写后的结果

4、日期和时间函数

  • CURDATE()或CURRENT_DATE() 返回当前的日期

  • CURTIME()或CURRENT_TIME() 返回当前的时间

  • DATE_ADD(date,INTERVAL int keyword)返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECTDATE_ADD(CURRENT_DATE,INTERVAL 6 MONTH);

  • DATE_FORMAT(date,fmt) 依照指定的fmt格式格式化日期date值

  • DATE_SUB(date,INTERVAL int keyword)返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECTDATE_SUB(CURRENT_DATE,INTERVAL 6 MONTH);

  • DAYOFWEEK(date) 返回date所代表的一星期中的第几天(1~7)

  • DAYOFMONTH(date) 返回date是一个月的第几天(1~31)

  • DAYOFYEAR(date) 返回date是一年的第几天(1~366)

  • DAYNAME(date) 返回date的星期名,如:SELECT DAYNAME(CURRENT_DATE);

  • FROM_UNIXTIME(ts,fmt) 根据指定的fmt格式,格式化UNIX时间戳ts

  • HOUR(time) 返回time的小时值(0~23)

  • MINUTE(time) 返回time的分钟值(0~59)

  • MONTH(date) 返回date的月份值(1~12)

  • MONTHNAME(date) 返回date的月份名,如:SELECT

  • MONTHNAME(CURRENT_DATE);

  • NOW() 返回当前的日期和时间

  • QUARTER(date) 返回date在一年中的季度(1~4),如SELECT QUARTER(CURRENT_DATE);

  • WEEK(date) 返回日期date为一年中第几周(0~53)

  • YEAR(date) 返回日期date的年份(1000~9999) 一些示例:获取当前系统时间: 

  • SELECT FROM_UNIXTIME(UNIX_TIMESTAMP());

  • SELEC TEXTRACT(YEAR_MONTH FROM CURRENT_DATE);

  • SELECT EXTRACT(DAY_SECOND FROM CURRENT_DATE);

  • SELECT EXTRACT(HOUR_MINUTE FROM CURRENT_DATE);

  • 返回两个日期值之间的差值(月数):

  • SELECT PERIOD_DIFF(200302,199802)

  • 在Mysql中计算年龄: 

  • SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(birthday)),’%Y’)+0 AS age FROM employee;

  • 这样,如果Brithday是未来的年月日的话,计算结果为0。 

  • 下面的SQL语句计算员工的绝对年龄,即当Birthday是未来的日期时,将得到负值。

  • SELECT DATE_FORMAT(NOW(), ‘%Y’) - DATE_FORMAT(birthday, ‘%Y’) -(DATE_FORMAT(NOW(), ‘00-%m-%d’) 

5、加密函数

  • AES_ENCRYPT(str,key) :返回用密钥key对字符串str利用高级加密标准算法加密后的结果,调用AES_ENCRYPT的结果是一个二进制字符串,以BLOB类型存储

  • AES_DECRYPT(str,key) 返回用密钥key对字符串str利用高级加密标准算法解密后的结果

  • DECODE(str,key):使用key作为密钥解密加密字符串str

  • ENCRYPT(str,salt): 使用UNIXcrypt()函数,用关键词salt(一个可以惟一确定口令的字符串,就像钥匙一样)加密字符串str

  • ENCODE(str,key): 使用key作为密钥加密字符串str,调用ENCODE()的结果是一个二进制字符串,它以BLOB类型存储

  • MD5() 计算字符串str的MD5校验和

  • PASSWORD(str) 返回字符串str的加密版本,这个加密过程是不可逆转的,和UNIX密码加密过程使用不同的算法。

  • SHA() 计算字符串str的安全散列算法(SHA)校验和

  • 示例: 
    SELECT ENCRYPT(‘root’,’salt’); 
    SELECT ENCODE(‘xufeng’,’key’); 
    SELECT DECODE(ENCODE(‘xufeng’,’key’),’key’); 
    #加解密放在一起 
    SELECT AES_ENCRYPT(‘root’,’key’); 
    SELECT AES_DECRYPT(AES_ENCRYPT(‘root’,’key’),’key’); 
    SELECT MD5(‘123456’); 
    SELECT SHA(‘123456’);

6、控制流函数

MySQL有4个函数是用来进行条件操作的,这些函数可以实现SQL的条件逻辑,允许开发者将一些应用程序业务逻辑转换到数据库后台。

  • MySQL控制流函数:

  • CASE WHEN[test1] THEN [result1]…ELSE [default] END 
    如果testN是真,则返回resultN,否则返回default

  • CASE [test] WHEN[val1] THEN [result]…ELSE [default]END

  • 如果test和valN相等,则返回resultN,否则返回default

  • IF(test,t,f) 如果test是真,返回t;否则返回f

  • IFNULL(arg1,arg2) 如果arg1不是空,返回arg1,否则返回arg2

  • NULLIF(arg1,arg2) 如果arg1=arg2返回NULL;否则返回arg1

  • 这些函数的第一个是IFNULL(),它有两个参数,并且对第一个参数进行判断。如果第一个参数不是NULL,函数就会向调用者返回第一个参数;如果是NULL,将返回第二个参数。

  • 如:SELECT IFNULL(1,2), IFNULL(NULL,10),IFNULL(4*NULL,’false’); NULLIF()函数将会检验提供的两个参数是否相等,如果相等,则返回NULL,如果不相等,就返回第一个参数。

  • 如:SELECT NULLIF(1,1),NULLIF(‘A’,’B’),NULLIF(2+3,4+1);

  • 和许多脚本语言提供的IF()函数一样,MySQL的IF()函数也可以建立一个简单的条件测试,这个函数有三个参数,第一个是要被判断的表达式,如果表达式为真,IF()将会返回第二个参数,如果为假,IF()将会返回第三个参数。

  • 如:SELECTIF(1eccf31e50338154ca5b472639ff61fde100,’true’,’false’);

  • IF()函数在只有两种可能结果时才适合使用。然而,在现实世界中,我们可能发现在条件测试中会需要多个分支。在这种情况下,MySQL提供了CASE函数,它和PHP及Perl语言的switch-case条件例程一样。

  • CASE函数的格式有些复杂,通常如下所示: CASE [expression to be evaluated] WHEN [val 1] THEN [result 1] WHEN [val 2] THEN [result 2] WHEN [val 3] THEN [result 3] …… WHEN [val n] THEN [result n] ELSE [default result] END

  • 这里,第一个参数是要被判断的值或表达式,接下来的是一系列的WHEN-THEN块,每一块的第一个参数指定要比较的值,如果为真,就返回结果。所有的WHEN-THEN块将以ELSE块结束,当END结束了所有外部的CASE块时,如果前面的每一个块都不匹配就会返回ELSE块指定的默认结果。如果没有指定ELSE块,而且所有的WHEN-THEN比较都不是真,MySQL将会返回NULL。

  • CASE函数还有另外一种句法,有时使用起来非常方便,如下: CASE WHEN [conditional test 1] THEN [result 1] WHEN [conditional test 2] THEN [result 2] ELSE [default result] END 这种条件下,返回的结果取决于相应的条件测试是否为真。

  • 示例: 

  • mysql>SELECT CASE ‘green’ WHEN ‘red’ THEN ‘stop’ WHEN ‘green’ THEN ‘go’ END;

  • SELECT CASE 9 WHEN 1 THEN ‘a’ WHEN 2 THEN ‘b’ ELSE ‘N/A’ END; SELECT CASE WHEN (2+2)=4 THEN ‘OK’ WHEN(2+2)a8093152e673feb7aba1828c435320944 THEN ‘not OK’ END ASSTATUS;

  • SELECT Name,IF((IsActive = 1),’已激活’,’未激活’) AS RESULT FROMUserLoginInfo; SELECT fname,lname,(math+sci+lit) AS total, CASE WHEN (math+sci+lit) < 50 THEN ‘D’ WHEN (math+sci+lit) BETWEEN 50 AND 150 THEN ‘C’ WHEN (math+sci+lit) BETWEEN 151 AND 250 THEN ‘B’ ELSE ‘A’ END AS grade FROM marks; SELECT IF(ENCRYPT(‘sue’,’ts’)=upass,’allow’,’deny’) AS LoginResultFROM users WHERE uname = ‘sue’;#一个登陆验证

7、格式化函数

  • DATE_FORMAT(date,fmt) 依照字符串fmt格式化日期date值

  • FORMAT(x,y) 把x格式化为以逗号隔开的数字序列,y是结果的小数位数

  • INET_ATON(ip) 返回IP地址的数字表示

  • INET_NTOA(num) 返回数字所代表的IP地址

  • TIME_FORMAT(time,fmt) 依照字符串fmt格式化时间time值 
    其中最简单的是FORMAT()函数,它可以把大的数值格式化为以逗号间隔的易读的序列。

  • 示例: 

  • SELECT FORMAT(34234.34323432,3);

  • SELECT DATE_FORMAT(NOW(),’%W,%D %M %Y %r’);

  • SELECT DATE_FORMAT(NOW(),’%Y-%m-%d’);

  • SELECT DATE_FORMAT(19990330,’%Y-%m-%d’);

  • SELECT DATE_FORMAT(NOW(),’%h:%i %p’);

  • SELECT INET_ATON(‘10.122.89.47’);

  • SELECT INET_NTOA(175790383);

8、类型转化函数

  • 为了进行数据类型转化,MySQL提供了CAST()函数,它可以把一个值转化为指定的数据类型。

类型有:BINARY,CHAR,DATE,TIME,DATETIME,SIGNED,UNSIGNED

  • 示例: 

SELECT CAST(NOW() AS SIGNED INTEGER),CURDATE()+0; 
SELECT ‘f’=BINARY ‘F’,’f’=CAST(‘F’ AS BINARY);

9、系统信息函数

  • DATABASE() 返回当前数据库名

  • BENCHMARK(count,expr) 将表达式expr重复运行count次

  • CONNECTION_ID() 返回当前客户的连接ID

  • FOUND_ROWS() 返回最后一个SELECT查询进行检索的总行数

  • USER()或SYSTEM_USER() 返回当前登陆用户名

  • VERSION() 返回MySQL服务器的版本

  • 示例: 
    SELECT DATABASE(),VERSION(),USER(); 
    SELECT BENCHMARK(9999999,LOG(RAND()*PI())); 
    #该例中,MySQL计算LOG(RAND()*PI())表达式9999999次。

以上就是 【MySQL 09】常用函数的内容,更多相关内容请关注PHP中文网(www.php.cn)!


声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
MySQL的许可与其他数据库系统相比如何?MySQL的许可与其他数据库系统相比如何?Apr 25, 2025 am 12:26 AM

MySQL使用的是GPL许可证。1)GPL许可证允许自由使用、修改和分发MySQL,但修改后的分发需遵循GPL。2)商业许可证可避免公开修改,适合需要保密的商业应用。

您什么时候选择InnoDB而不是Myisam,反之亦然?您什么时候选择InnoDB而不是Myisam,反之亦然?Apr 25, 2025 am 12:22 AM

选择InnoDB而不是MyISAM的情况包括:1)需要事务支持,2)高并发环境,3)需要高数据一致性;反之,选择MyISAM的情况包括:1)主要是读操作,2)不需要事务支持。InnoDB适合需要高数据一致性和事务处理的应用,如电商平台,而MyISAM适合读密集型且无需事务的应用,如博客系统。

在MySQL中解释外键的目的。在MySQL中解释外键的目的。Apr 25, 2025 am 12:17 AM

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

MySQL中有哪些不同类型的索引?MySQL中有哪些不同类型的索引?Apr 25, 2025 am 12:12 AM

MySQL中有四种主要的索引类型:B-Tree索引、哈希索引、全文索引和空间索引。1.B-Tree索引适用于范围查询、排序和分组,适合在employees表的name列上创建。2.哈希索引适用于等值查询,适合在MEMORY存储引擎的hash_table表的id列上创建。3.全文索引用于文本搜索,适合在articles表的content列上创建。4.空间索引用于地理空间查询,适合在locations表的geom列上创建。

您如何在MySQL中创建索引?您如何在MySQL中创建索引?Apr 25, 2025 am 12:06 AM

toCreateAnIndexinMysql,usethecReateIndexStatement.1)forasingLecolumn,使用“ createIndexIdx_lastNameEnemployees(lastName); 2)foracompositeIndex,使用“ createIndexIndexIndexIndexIndexDx_nameOmplayees(lastName,firstName,firstName);” 3)forauniqe instex,creationexexexexex,

MySQL与Sqlite有何不同?MySQL与Sqlite有何不同?Apr 24, 2025 am 12:12 AM

MySQL和SQLite的主要区别在于设计理念和使用场景:1.MySQL适用于大型应用和企业级解决方案,支持高性能和高并发;2.SQLite适合移动应用和桌面软件,轻量级且易于嵌入。

MySQL中的索引是什么?它们如何提高性能?MySQL中的索引是什么?它们如何提高性能?Apr 24, 2025 am 12:09 AM

MySQL中的索引是数据库表中一列或多列的有序结构,用于加速数据检索。1)索引通过减少扫描数据量提升查询速度。2)B-Tree索引利用平衡树结构,适合范围查询和排序。3)创建索引使用CREATEINDEX语句,如CREATEINDEXidx_customer_idONorders(customer_id)。4)复合索引可优化多列查询,如CREATEINDEXidx_customer_orderONorders(customer_id,order_date)。5)使用EXPLAIN分析查询计划,避

说明如何使用MySQL中的交易来确保数据一致性。说明如何使用MySQL中的交易来确保数据一致性。Apr 24, 2025 am 12:09 AM

在MySQL中使用事务可以确保数据一致性。1)通过STARTTRANSACTION开始事务,执行SQL操作后用COMMIT提交或ROLLBACK回滚。2)使用SAVEPOINT可以设置保存点,允许部分回滚。3)性能优化建议包括缩短事务时间、避免大规模查询和合理使用隔离级别。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)