mysql
SELECT GREATEST(2,0);//2
SELECT GREATEST('B','A','C');//C
当有2或多个参数时,返回值为最大(最大值的)参数。比较参数所依据的规律同LEAST()相同。
SELECT 'wefwf' IN (0,3,5,'wefwf');//1
若expr 为IN列表中的任意一个值,则其返回值为 1 , 否则返回值为0。
如expr 为NULL,那么ISNULL() 的返回值为 1,否则返回值为 0
SELECT ISNULL(1+1);//0
INTERVAL(N,N1,N2,N3,...)
假如N < N1,则返回值为0;假如N < N2 等等,则返回值为1;假如N 为NULL,则返回值为 -1 。所有的参数均按照整数处理。为了这个函数的正确运行,必须满足 N1 < N2 < N3 < ……< Nn 。其原因是使用了二分查找(极快速)。
SELECT INTERVAL(23, 1, 15, 17, 30, 44, 200);//3
@TODO...
LEAST(value1,value2,...)
在有两个或多个参数的情况下, 返回值为最小 (最小值) 参数。用一下规则将自变量进行对比:
假如返回值被用在一个 INTEGER 语境中,或是所有参数均为整数值,则将其作为整数值进行比较。
假如返回值被用在一个 REAL语境中,或所有参数均为实值,则 将其作为实值进行比较。
假如任意一个参数是一个区分大小写的字符串,则将参数按照区分大小写的字符串进行比较。
在其它情况下,将参数作为区分大小写的字符串进行比较。
假如任意一个自变量为NULL,则 LEAST()的返回值为NULL 。
SELECT LEAST(2,0);//0
逻辑AND。当所有操作数均为非零值、并且不为NULL时,计算所得结果为 1 ,当一个或多个操作数为0 时,所得结果为 0 ,其余情况返回值为 NULL 。
SELECT 1 && 1;//1
逻辑 OR。当两个操作数均为非 NULL值时,如有任意一个操作数为非零值,则结果为1,否则结果为0。当有一个操作数为NULL时,如另一个操作数为非零值,则结果为1,否则结果为 NULL 。假如两个操作数均为 NULL,则所得结果为 NULL。
SELECT 1 || 0; //1
在第一个方案的返回结果中, value=compare-value。而第二个方案的返回结果是第一种情况的真实结果。如果没有匹配的结果值,则返回结果为ELSE后的结果,如果没有ELSE 部分,则返回值为 NULL。
SELECT CASE 1 WHEN 1 THEN 'one' WHEN 2 THEN 'two' ELSE 'more' END; //'one'
IF(expr1,expr2,expr3)
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定。
SELECT IF(1>2,2,3);//3
SELECT IF(1<2,'yes ','no'); //yes
IFNULL(expr1,expr2)
假如expr1 不为 NULL,则 IFNULL() 的返回值为 expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。
SELECT IFNULL(1,0);//1
返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。或许有一个或多个参数。 如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast
SELECT CONCAT('My', 'S', 'QL');//MySQL
SELECT CONCAT('My', NULL, 'QL'); //NULL
CONCAT_WS(separator,str1,str2,...)
CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。 第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。
SELECT CONCAT_WS(',','First name','Second name','Last Name');//'First name,Second name,Last Name'
ELT(N,str1,str2,str3,...)
若N = 1,则返回值为 str1 ,若N = 2,则返回值为 str2 ,以此类推。 若N 小于1或大于参数的数目,则返回值为 NULL 。 ELT() 是 FIELD()的补数。
SELECT ELT(1, 'ej', 'Heja', 'hej', 'foo');//ej
FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中, 则返回值的范围在 1 到 N 之间 。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 这个函数在第一个参数包含一个逗号(‘,’)时将无法正常运行。
SELECT FIND_IN_SET('b','a,b,c,d');//2
LEFT(str,len)
返回从字符串str 开始的len 最左字符。
SELECT LEFT('foobarbar', 5);//fooba
LENGTH(str)
返回值为字符串str 的长度,单位为字节。一个多字节字符算作多字节。这意味着 对于一个包含5个2字节字符的字符串, LENGTH() 的返回值为 10, 而 CHAR_LENGTH()的返回值则为5。
SELECT LENGTH('text');//4
LOCATE(substr,str) , LOCATE(substr,str,pos)
第一个语法返回字符串 str中子字符串substr的第一个出现位置。第二个语法返回字符串 str中子字符串substr的第一个出现位置, 起始位置在pos。如若substr 不在str中,则返回值为0。
SELECT LOCATE('bar', 'foobarbar');//4
LOWER(str)
返回字符串 str 以及所有根据最新的字符集映射表变为小写字母的字符 (默认为 cp1252 Latin1)。
SELECT LOWER('QUADRATICALLY');//quadratically
LPAD(str,len,padstr)
返回字符串 str, 其左边由字符串padstr 填补到len 字符长度。假如str 的长度大于len, 则返回值被缩短至 len 字符。
SELECT LPAD('hi',4,'??');//??hi
LTRIM(str)
返回字符串 str ,其引导空格字符被删除。
SELECT LTRIM(' barbar'); //barbar
REPEAT(str,count)
返回一个由重复的字符串str 组成的字符串,字符串str的数目等于count 。 若 count <= 0,则返回一个空字符串。若str 或 count 为 NULL,则返回 NULL 。
SELECT REPEAT('MySQL', 3);//MySQLMySQLMySQL
REPLACE(str,from_str,to_str)
返回字符串str 以及所有被字符串to_str替代的字符串from_str 。
SELECT REPLACE('www.mysql.com', 'w', 'Ww');//WwWwWw.mysql.com
REVERSE(str)
返回字符串 str ,顺序和字符顺序相反。
SELECT REVERSE('abc');//cba
RIGHT(str,len)
从字符串str 开始,返回最右len 字符。
SELECT RIGHT('foobarbar', 4);//rbar
RPAD(str,len,padstr)
返回字符串str, 其右边被字符串 padstr填补至len 字符长度。假如字符串str 的长度大于 len,则返回值被缩短到与 len 字符相同长度。
SELECT RPAD('hi',5,'?');//hi???
SELECT SUBSTRING('Quadratically',5);//ratically
SELECT SUBSTRING('foobarbar' FROM 4);//barbar
SUBSTRING_INDEX(str,delim,count)
在定界符 delim 以及count 出现前,从字符串str返回自字符串。若count为正值,则返回最终定界符(从左边开始)左边的一切内容。若count为负值,则返回定界符(从右边开始)右边的一切内容。
SELECT SUBSTRING_INDEX('www.mysql.com', '.', 2);//www.mysql
SELECT SUBSTRING_INDEX('www.mysql.com', '.', -2);//mysql.com
若想要将数字明确地转化为字符串,可使用 CAST()或 CONCAT()函数:
SELECT 38.8, CAST(38.8 AS CHAR);//38.8, '38.8'
ABS(X)
返回X 的绝对值。
SELECT ABS(-32);//32
SIGN(X)
返回参数作为-1、 0或1的符号,该符号取决于X 的值为负、零或正。
TRUNCATE(X,D)
返回被舍去至小数点后D位的数字X。若D 的值为 0, 则结果不带有小数点或不带有小数部分。可以将D设为负数,若要截去(归零) X小数点左起第D位开始后面所有低位的值.
SELECT TRUNCATE(1.223,1);//1.2
ADDDATE(date,INTERVAL expr type) ADDDATE(expr,days)
当被第二个参数的INTERVAL格式激活后, ADDDATE()就是DATE_ADD()的同义词。相关函数SUBDATE() 则是DATE_SUB()的同义词。对于INTERVAL参数上的信息 ,请参见关于DATE_ADD()的论述。
SELECT DATE_ADD('1998-01-02', INTERVAL 31 DAY);//1998-02-02
CURDATE()//CURTIME()
DATEDIFF(expr,expr2)
DATEDIFF() 返回起始时间 expr和结束时间expr2之间的天数。Expr和expr2 为日期或 date-and-time 表达式。计算中只用到这些值的日期部分。
SELECT DATEDIFF('1997-12-31 23:59:59','1997-12-30');//1