mysql

作者: wangxl999 | 来源:发表于2018-09-29 15:36 被阅读0次

    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

    相关文章

      网友评论

          本文标题:mysql

          本文链接:https://www.haomeiwen.com/subject/xyqboftx.html