MySql的一些内置函数

来源:互联网 发布:阿里云企业邮箱设置 编辑:程序博客网 时间:2024/05/29 04:05

Num01–>字符串函数

1,查看字符的ascii码值ascii(str),str是空串时返回0select ascii('a');2,查看ascii码值对应的字符char(数字)select char(97);3,拼接字符串concat(str1,str2...)select concat(12,34,'ab');4,包含字符个数length(str)select length('abc');5,截取字符串left(str,len)返回字符串str的左端len个字符right(str,len)返回字符串str的右端len个字符substring(str,pos,len)返回字符串str的位置pos起len个字符select substring('abc123',2,3);6,去除空格ltrim(str)返回删除了左空格的字符串strrtrim(str)返回删除了右空格的字符串strtrim([方向 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');7,返回由n个空格字符组成的一个字符串space(n)select space(10);8,替换字符串replace(str,from_str,to_str)select replace('abc123','123','def');9,大小写转换,函数如下lower(str)upper(str)select lower('aBcD');

Num02–>数学函数

1,求绝对值abs(n)select abs(-32);2,求m除以n的余数mod(m,n),同运算符%select mod(10,3);select 10%3;3,地板floor(n),表示不大于n的最大整数select floor(2.3);4,天花板ceiling(n),表示不小于n的最大整数select ceiling(2.3);5,求四舍五入值round(n,d),n表示原数,d表示小数位置,默认为0select round(1.6);6,求x的y次幂pow(x,y)select pow(2,3);7,获取圆周率PI()select PI();8,随机数rand(),值为0-1.0的浮点数select rand();还有其它很多三角函数,使用时可以查询文档

Num03–>日期函数

1,获取子值,值为整数类型,函数如下year(date)返回date的年份(范围在10009999)month(date)返回date中的月份数值day(date)返回date中的日期数值hour(time)返回time的小时数(范围是023)minute(time)返回time的分钟数(范围是059)second(time)返回time的秒数(范围是059)select year('2016-12-21');2,日期计算,使用+-运算符,数字后面的关键字为yearmonthdayhourminutesecondselect '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();

Num04–>类型转换函数

有cast和convert两个函数语法如下:cast(value as type)convert(value, type)value表示要转换的值type表示目标类型目标类型如下:二进制binary字符型char,可指定字符个数如char(10)日期date时间time日期时间型datetime浮点数decimal整数signed无符号整数unsigned例如:SELECT CONVERT('125.83',SIGNED);SELECT CAST('125.83' AS signed);

Num05–>流程控制函数

1,类似于python中的if语句,进行选择判断case语法1:等值判断说明:当值等于某个比较值的时候,对应的结果会被返回;如果所有的比较值都不相等则返回else的结果;如果没有else并且所有比较值都不相等则返回nullcase 值 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则返回nullcase 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;2if语句说明:如果表达式的结果为true,则返回结果1,否则返回结果2if(表达式,结果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;
0 0
原创粉丝点击