一、数学函数
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位小数的结果
二、聚合函数(常用于GROUP BY从句的SELECT查询中)
AVG(col) 返回指定列的平均值
COUNT(col) 返回指定列中非NULL值的个数
MIN(col) 返回指定列的最小值
MAX(col) 返回指定列的最大值
SUM(col) 返回指定列的所有值之和
GROUP_CONCAT(col) 返回由属于一组的列值连接组合而成的结果
三、字符串函数
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中所有字符转变为大写后的结果
四、日期和时间函数
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)
一些示例: 获取当前系统时间: ?
1 2 3 4 |
SELECT FROM_UNIXTIME(UNIX_TIMESTAMP()); SELECT EXTRACT(YEAR_MONTH FROM CURRENT_DATE ); SELECT EXTRACT(DAY_SECOND FROM CURRENT_DATE ); SELECT EXTRACT(HOUR_MINUTE FROM CURRENT_DATE ); |
返回两个日期值之间的差值(月数): ?
1 |
SELECT PERIOD_DIFF(200302,199802); |
在Mysql中计算年龄: ?
1 |
SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(birthday)), '%Y' )+0 AS age FROM employee; |
这样,如果Brithday是未来的年月日的话,计算结果为0。 下面的SQL语句计算员工的绝对年龄,即当Birthday是未来的日期时,将得到负值。 ?
1 |
SELECT DATE_FORMAT(NOW(), '%Y' ) - DATE_FORMAT(birthday, '%Y' ) -(DATE_FORMAT(NOW(), '00-%m-%d' ) '00-%m-%d' )) AS age from employee |
五、加密函数
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)校验和
示例: ?
1 2 3 4 5 6 7 |
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' ); |
六、控制流函数 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(1<10,2,3),IF(56>100,'true','false'); IF() 函数在只有两种可能结果时才适合使用。然而,在现实世界中,我们可能发现在条件测试中会需要多个分支。在这种情况下,MySQL提供了CASE函数,它和PHP及Perl语言的switch-case 条件例程一样。 CASE函数的格式有些复杂,通常如下所示: ?
1 2 3 4 5 6 7 8 |
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函数还有另外一种句法,有时使用起来非常方便,如下: ?
1 2 3 4 5 |
CASE WHEN [conditional test 1] THEN [result 1] WHEN [conditional test 2] THEN [result 2] ELSE [ default result] END |
这种条件下,返回的结果取决于相应的条件测试是否为真。 示例: ?
1 2 3 4 5 6 7 8 9 10 11 12 13 |
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)<>4 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' ;#一个登陆验证 |
七、格式化函数
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() 函数,它可以把大的数值格式化为以逗号间隔的易读的序列。 示例: ?
1 2 3 4 5 6 7 |
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); |
八、类型转化函数 为了进行数据类型转化,MySQL提供了CAST() 函数,它可以把一个值转化为指定的数据类型。类型有:BINARY ,CHAR ,DATE ,TIME ,DATETIME ,SIGNED ,UNSIGNED 示例: ?
1 2 |
SELECT CAST (NOW() AS SIGNED INTEGER ),CURDATE()+0; SELECT 'f' = BINARY 'F' , 'f' = CAST ( 'F' AS BINARY ); |
九、系统信息函数
DATABASE() 返回当前数据库名
BENCHMARK(count,expr) 将表达式expr重复运行count次
CONNECTION_ID() 返回当前客户的连接ID
FOUND_ROWS() 返回最后一个SELECT查询进行检索的总行数
USER()或SYSTEM_USER() 返回当前登陆用户名
VERSION() 返回MySQL服务器的版本
示例: ?
1 2 |
SELECT DATABASE (),VERSION(), USER (); SELECTBENCHMARK(9999999,LOG(RAND()*PI()));#该例中,MySQL计算LOG(RAND()*PI())表达式9999999次。 |
另外一篇博文 MySQL数据库中提供了很丰富的函数。MySQL函数包括数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数、加密函数、格式化函数等。通过这些函数,可以简化用户的操作。例如,字符串连接函数可以很方便的将多个字符串连接在一起。在这一讲中将讲解的内容包括: 数学函数 字符串函数 日期和时间函数 条件判断函数 系统信息函数 加密函数 格式化函数 MySQL函数是MySQL数据库提供的内部函数。这些内部函数可以帮助用户更加方便的处理表中的数据。本小节中将简单介绍MySQL中包含哪几类函数,以及这几类函数的的使用范围和作用。MySQL函数包括数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数、加密函数等。SELECT语句及其条件表达式都可以使用这些函数。同时,INSERT 、UPDATE、DELECT语句及其条件表达式也可以使用这些函数。例如,表中的某个数据是负数,现在需要将这个数据显示为正数。这就可以使用绝对值函数。从上面可以知道,MySQL函数可以对表中数据进行相应的处理,以便得到用户希望得到的数据。这些函数可以使MySQL数据库的功能更加强大。 一、数学函数 数学函数是MySQL中常用的一类函数。主要用于处理数字,包括整型、浮点数等。数学函数包括绝对值函数、正弦函数、余弦函数、获取随机数的函数等。 ABS(X):返回X的绝对值 select ABS(-32); MOD(N,M)或%:返回N被M除的余数。 select MOD(15,7); select 15 % 7; FLOOR(X):返回不大于X的最大整数值。 select FLOOR(1.23); select FLOOR(-1.23); CEILING(X):返回不小于X的最小整数值。 select CEILING(1.23); select CEILING(-1.23); ROUND(X) :返回参数X的四舍五入的一个整数。 select ROUND(1.58); select ROUND(-1.58); 二、字符串函数 ASCII(str):返回字符串str的最左面字符的ASCII代码值。如果str是空字符串,返回0。如果str是NULL,返回NULL。 select ASCII('2'); select ASCII(2); select ASCII('dx') CONCAT(str1,str2,...):返回来自于参数连结的字符串。如果任何参数是NULL,返回NULL。可以有超过2个的参数。一个数字参数被变换为等价的字符串形式。 select CONCAT('My', 'S', 'QL'); select CONCAT('My', NULL, 'QL'); select CONCAT(14.3); LENGTH(str):返回字符串str的长度。 select LENGTH('text'); LOCATE(substr,str):返回子串substr在字符串str第一个出现的位置,如果substr不是在str里面,返回0. select LOCATE('bar', 'foobarbar'); select LOCATE('xbar', 'foobar'); INSTR(str,substr):返回子串substr在字符串str中的第一个出现的位置。 select INSTR('foobarbar', 'bar'); select INSTR('xbar', 'foobar'); LEFT(str,len):返回字符串str的最左面len个字符。 select LEFT('foobarbar', 5); RIGHT(str,len):返回字符串str的最右面len个字符。 select RIGHT('foobarbar', 4); SUBSTRING(str,pos):从字符串str的起始位置pos返回一个子串。 select SUBSTRING('Quadratically',5); TRIM(str):返回字符串str,所有前缀或后缀被删除了。 select TRIM(' bar '); LTRIM(str):返回删除了其前置空格字符的字符串str。 select LTRIM(' barbar'); RTRIM(str):返回删除了其拖后空格字符的字符串str。 select RTRIM(‘barbar ’); REPLACE(str,from_str,to_str):返回字符串str,其字符串from_str的所有出现由字符串to_str代替。 select REPLACE('www.mysql.com', 'w', 'Ww'); REPEAT(str,count):返回由重复countTimes次的字符串str组成的一个字符串。如果count <= 0,返回一个空字符串。如果str或count是NULL,返回NULL。 select REPEAT('MySQL', 3); REVERSE(str):返回颠倒字符顺序的字符串str。 select REVERSE('abc'); INSERT(str,pos,len,newstr):返回字符串str,在位置pos起始的子串且len个字符长的子串由字符串newstr代替。 select INSERT(‘whatareyou', 5, 3, ‘is'); 三、日期和时间函数 DAYOFWEEK(date):返回日期date的星期索引(1=星期天,2=星期一, …7=星期六)。 select DAYOFWEEK('1998-02-03'); select DAYOFWEEK(now()); WEEKDAY(date):返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。 select WEEKDAY('1997-11-05'); DAYOFMONTH(date):返回date的月份中的日期,在1到31范围内。 select DAYOFMONTH('1998-02-03'); DAYOFYEAR(date):返回date在一年中的日数, 在1到366范围内。 select DAYOFYEAR('1998-02-03'); MONTH(date):返回date的月份,范围1到12。 select MONTH('1998-02-03'); DAYNAME(date):返回date的星期名字。 select DAYNAME("1998-02-05"); MONTHNAME(date) :返回date的月份名字。 select MONTHNAME("1998-02-05"); QUARTER(date):返回date一年中的季度,范围1到4。 select QUARTER('98-04-01'); WEEK(date,first):对于星期天是一周的第一天的地方,有一个单个参数,返回date的周数,范围在0到52。2个参数形式WEEK()允许你指定星期是否开始于星期天或星期一。如果第二个参数是0,星期从星期天开始,如果第二个参数是1,从星期一开始。 select WEEK('2009-02-20'); select WEEK('2009-02-20',0); select WEEK('2009-02-20',1); YEAR(date):返回date的年份,范围在1000到9999。 select YEAR('98-02-03'); HOUR(time):返回time的小时,范围是0到23。 select HOUR('10:05:03'); MINUTE(time):返回time的分钟,范围是0到59。 select MINUTE('98-02-03 10:05:03'); SECOND(time):回来time的秒数,范围是0到59。 select SECOND('10:05:03'); DATE_ADD(date,INTERVAL expr type) ,进行日期增加的操作,可以精确到秒 DATE_SUB(date,INTERVAL expr type) ,进行日期减少的操作,可以精确到秒 SELECT "1997-12-31 23:59:59" + INTERVAL 1 SECOND; SELECT INTERVAL 1 DAY + "1997-12-31"; SELECT "1998-01-01" - INTERVAL 1 SECOND; SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL 1 SECOND); SELECT DATE_ADD("1997-12-31 23:59:59", INTERVAL "1:1" MINUTE_SECOND); SELECT DATE_SUB("1998-01-01 00:00:00", INTERVAL "1 1:1:1" DAY_SECOND); SELECT DATE_SUB("1998-01-02", INTERVAL 31 DAY); CURRENT_DATE:以‘YYYY-MM-DD’或YYYYMMDD格式返回今天日期值,取决于函数在一个字符串还是数字上下文被使用。 select CURDATE(); CURRENT_TIME:以‘HH:MM:SS’或HHMMSS格式返回当前时间值 select CURTIME(); NOW():以‘YYYY-MM-DD HH:MM:SS’或YYYYMMDDHHMMSS格式返回当前的日期和时间 select NOW(); 四、控制流程函数 CASE value WHEN [compare-value] THEN result [WHEN [compare-value] THEN result ...] [ELSE result] END CASE WHEN [condition] THEN result [WHEN [condition] THEN result ...] [ELSE result] END 在第一个方案的返回结果中, value=compare-value。而第二个方案的返回结果是第一种情况的真实结果。如果没有匹配的结果值,则返回结果为ELSE后的结果,如果没有ELSE 部分,则返回值为 NULL。 SELECT CASE 11 WHEN 1 THEN 'one' WHEN 2 THEN 'two' ELSE 'more' END; SELECT CASE WHEN 1>0 THEN 'true' ELSE 'false' END; SELECT CASE BINARY 'B' WHEN 'a' THEN 1 WHEN 'b' THEN 2 END; IF(expr1,expr2,expr3) 如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。 SELECT IF(1>2,2,3); SELECT IF(1<2,'yes ','no'); SELECT IF(STRCMP('test','test1'),'no','yes'); Strcmp(str1,str2):如果str1>str2返回1,str1=str2反回0,str1 STRCMP(expr1,expr2) 如果字符串相同,STRCMP()返回0,如果第一参数根据当前的排序次序小于第二个,返回-1,否则返回1。 select STRCMP('text', 'text2'); select STRCMP('text2', 'text'); select STRCMP('text', 'text'); 五、系统信息函数 系统信息函数用来查询MySQL数据库的系统信息。例如,查询数据库的版本,查询数据库的当前用户等。本小节将详细讲解系统信息函数的作用和使用方法。
获取MySQL版本号、连接数、数据库名的函数
VERSION()函数返回数据库的版本号; CONNECTION_ID()函数返回服务器的连接数,也就是到现在为止MySQL服务的连接次数; DATABASE()和SCHEMA()返回当前数据库名。 获取用户名的函数 USER()、SYSTEM_USER()、SESSION_USER()、CURRENT_USER()和CURRENT_USER这几个函数可以返回当前用户的名称。 获取字符串的字符集和排序方式的函数 CHARSET(str)函数返回字符串str的字符集,一般情况这个字符集就是系统的默认字符集;COLLATION(str)函数返回字符串str的字符排列方式。 获取最后一个自动生成的ID值的函数 LAST_INSERT_ID()函数返回最后生成的AUTO_INCREMENT值。 六、加密函数 加密函数是MySQL中用来对数据进行加密的函数。因为数据库中有些很敏感的信息不希望被其他人看到,就应该通过加密方式来使这些数据变成看似乱码的数据。例如用户的密码,就应该经过加密。本小节将详细讲解加密函数的作用和使用方法。 下面是各种加密函数的名称、作用和使用方法。 加密函数PASSWORD(str) PASSWORD(str)函数可以对字符串str进行加密。一般情况下,PASSWORD(str)函数主要是用来给用户的密码加密的。下面使用PASSWORD(str)函数为字符串“abcd”加密。 加密函数MD5(str) MD5(str)函数可以对字符串str进行加密。MD5(str)函数主要对普通的数据进行加密。下面使用MD5(str)函数为字符串“abcd”加密。 加密函数ENCODE(str,pswd_str) ENCODE(str,pswd_str)函数可以使用字符串pswd_str来加密字符串str。加密的结果是一个二进制数,必须使用BLOB类型的字段来保存它。 解密函数 DECODE(crypt_str,pswd_str)函数可以使用字符串pswd_str来为crypt_str解密。crypt_str是通过ENCODE(str,pswd_str)加密后的二进制数据。字符串pswd_str应该与加密时的字符串pswd_str是相同的。下面使用DECODE(crypt_str,pswd_str)为ENCODE(str,pswd_str)加密的数据解密。 七、其它函数 格式化函数FORMAT(x,n) FORMAT(x,n)函数可以将数字x进行格式化,将x保留到小数点后n位。这个过程需要进行四舍五入。例如FORMAT(2.356,2)返回的结果将会是2.36;FORMAT(2.353,2)返回的结果将会是2.35。下面使用FORMAT(x,n)函数来讲235.3456和235.3454进行格式化,都保留到小数点后3位。 不同进制的数字进行转换的函数 ASCII(s)返回字符串s的第一个字符的ASCII码;BIN(x)返回x的二进制编码;HEX(x)返回x的十六进制编码;OCT(x)返回x的八进制编码;CONV(x,f1,f2)将x从f1进制数变成f2进制数。 和下面的 IP地址与数字相互转换的函数 INET_ATON(IP)函数可以将IP地址转换为数字表示;INET_NTOA(n)函数可以将数字n转换成IP的形式。其中,INET_ATON(IP)函数中IP值需要加上引号。这两个函数互为反函数。 加锁函数和解锁函数 GET_LOCT(name,time)函数定义一个名称为nam、持续时间长度为time秒的锁。如果锁定成功,返回1;如果尝试超时,返回0;如果遇到错误,返回NULL。RELEASE_LOCK(name)函数解除名称为name的锁。如果解锁成功,返回1;如果尝试超时,返回0;如果解锁失败,返回NULL;IS_FREE_LOCK(name)函数判断是否使用名为name的锁。如果使用,返回0;否则,返回1。 重复执行指定操作的函数 BENCHMARK(count,expr)函数将表达式expr重复执行count次,然后返回执行时间。该函数可以用来判断MySQL处理表达式的速度。 改变字符集的函数 CONVERT(s USING cs)函数将字符串s的字符集变成cs CAST(x AS type)和CONVERT(x,type)这两个函数将x变成type类型。这两个函数只对BINARY、CHAR、DATE、DATETIME、TIME、SIGNED INTEGER、UNSIGNED INTEGER这些类型起作用。但两种方法只是改变了输出值的数据类型,并没有改变表中字段的类型。 原文地址:https://blog.csdn.net/sinat_38899493/article/details/78710482 |