• mysql 内置函数


    SELECT CONVERT('125.83',SIGNED);
    SELECT CAST('125.83' AS signed);
    

      

    字符串函数

    • 查看字符的ascii码值ascii(str),str是空串时返回0
    select ascii('a');
    

      

    • 查看ascii码值对应的字符char(数字)
    select char(97);
    

      

    • 拼接字符串concat(str1,str2...)
    select concat(12,34,'ab');
    

      

    • 包含字符个数length(str)
    select length('abc');
    

      

    • 截取字符串
      • left(str,len)返回字符串str的左端len个字符
      • right(str,len)返回字符串str的右端len个字符
      • substring(str,pos,len)返回字符串str的位置pos起len个字符
    select substring('abc123',2,3);
    

      

    • 去除空格
      • ltrim(str)返回删除了左空格的字符串str
      • rtrim(str)返回删除了右空格的字符串str
      • trim([方向 remstr from str)返回从某侧删除remstr后的字符串str,方向词包括both、leading、trailing,表示两侧、左、右
    select trim('  bar   ');
    select trim(leading 'x' FROM 'xxxbarxxx');
    select trim(both 'x' FROM 'xxxbarxxx');
    select trim(trailing 'x' FROM 'xxxbarxxx');
    

      

    • 返回由n个空格字符组成的一个字符串space(n)
    select space(10);
    

      

    • 替换字符串replace(str,from_str,to_str)
    select replace('abc123','123','def');
    

      

    • 大小写转换,函数如下
      • lower(str)
      • upper(str)
    select lower('aBcD');
    

      






    数学函数

    • 求绝对值abs(n)
    select abs(-32);
    

      

    • 求m除以n的余数mod(m,n),同运算符%
    select mod(10,3);
    select 10%3;
    

      

    • 地板floor(n),表示不大于n的最大整数
    select floor(2.3);
    

      

    • 天花板ceiling(n),表示不小于n的最大整数
    select ceiling(2.3);
    

      

    • 求四舍五入值round(n,d),n表示原数,d表示小数位置,默认为0
    select round(1.6);
    

      

    • 求x的y次幂pow(x,y)
    select pow(2,3);
    

      

    • 获取圆周率PI()
    select PI();
    

      

    • 随机数rand(),值为0-1.0的浮点数
    select rand();
    

      






    日期时间函数

    • 获取子值,值为整数类型,函数如下
      • year(date)返回date的年份(范围在1000到9999)
      • month(date)返回date中的月份数值
      • day(date)返回date中的日期数值
      • hour(time)返回time的小时数(范围是0到23)
      • minute(time)返回time的分钟数(范围是0到59)
      • second(time)返回time的秒数(范围是0到59)
    select year('2016-12-21');
    

      

    • 日期计算,使用+-运算符,数字后面的关键字为year、month、day、hour、minute、second
    select '2016-12-21'+interval 1 day;
    

      

    • 日期格式化date_format(date,format)
    • 参数format可选值如下
    %Y 获取年,返回完整年份
    %y 获取年,返回简写年份
    %m 获取月,返回月份
    %d 获取日,返回天值
    %H 获取时,返回24进制的小时数
    %h 获取时,返回12进制的小时数
    %i 获取分,返回分钟数
    %s 获取秒,返回秒数
    
    • 示例如下:将使用-拼接的日期转换为使用空格拼接
    select date_format('2016-12-21','%Y %m %d');
    

      

    • 当前日期current_date()
    select current_date();
    

      

    • 当前时间current_time()
    select current_time();
    

      

    • 当前日期时间now()
    select now();
    

      






    类型转换函数

    • 有cast和convert两个函数

    • 语法如下:

    cast(value as type)
    convert(value, type)
    

      

    • value表示要转换的值
    • type表示目标类型
    • 目标类型如下:

      • 二进制binary
      • 字符型char,可指定字符个数如char(10)
      • 日期date
      • 时间time
      • 日期时间型datetime
      • 浮点数decimal
      • 整数signed
      • 无符号整数unsigned






    流程控制

    • 类似于python中的if语句,进行选择判断
    • case语法1:等值判断
    • 说明:当值等于某个比较值的时候,对应的结果会被返回;如果所有的比较值都不相等则返回else的结果;如果没有else并且所有比较值都不相等则返回null
    case 值 when 比较值1 then 结果1 when 比较值2 then 结果2 ... else 结果 end
    例:
    select case 1 when 1 then 'one' when 2 then 'two' else 'zero' end as result;
    

      

    • case语法2:非等值判断,可以进行>、<、!=等判断
    • 说明:当某个条件返回true时,对应的结果被返回;如果所有的条件都不返回true则返回else的结果;如果没有else并且所有条件都不返回true则返回null
    case when 条件1 then 结果1 when 条件2 then 结果2 ... else 结果 end
    例:
    select case when 1>2 then 'part1' when 3>2 then 'part2' else 'part3' end as result;
    

      

    • if语句
    • 说明:如果表达式的结果为true,则返回结果1,否则返回结果2
    if(表达式,结果1,结果2)
    例:
    select if(1>2,2,3) as result;
    

      

    • ifnull语句
    • 说明:如果表达式1不为null,则返回表达式1的结果,否则返回表达式2的结果
    ifnull(表达式1,表达式2)
    例:
    select ifnull(1,0) as result;
    

      

    • nullif语句
    • 说明:如果表达式1等于表达式2,则返回null,否则返回表达式1的结果
    nullif(表达式1,表达式2)
    例:
    select nullif(1,0) as result;
    

      

  • 相关阅读:
    JavaScript系列:JavaScript简介
    Fit自适应布局
    JavaScript数值类型及变量
    表格列Column
    JavaScript系列:ECMAScript引用类型
    Absolute绝对定位
    JavaScript系列:ECMAScript运算符
    JavaScript系列:ECMAScript类型转换
    jQuery Uploadify在ASP.NET MVC3中的使用
    JavaScript系列:ECMAScript语句
  • 原文地址:https://www.cnblogs.com/yoyo1216/p/10129919.html
Copyright © 2020-2023  润新知