字符串函数
查看字符的ascii码值ascii(str),str是空串时返回0
查看ascii码值对应的字符char(数字):select char(97);
拼接字符串concat(str1,str2...):selectconcat(12,34,'ab');
包含字符个数length(str):selectlength('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)
大小写转换,函数如下lower(str)、upper(str)
数学函数
求绝对值ABS(n)的select abs(-32);
求米除以Ñ的余数模(M,N),同运算符%:selectmod(10,3);select 10%3;
地板地板(n)时,表示不大于Ñ的最大整数:selectfloor(2.3);
天花板的天花板(n)时,表示不小于Ñ的最大整数:selectceiling(2.3);
求四舍五入值轮(N,D)中,n表示原数,D表示小数位置,默认为0
select round(1.6);
求X的ý次幂POW(X,Y):select pow(2,3);
获取圆周率PI():select PI();
随机数RAND(),值为0-1.0的浮点数:select rand();
日期时间函数
获取子值,值为整数类型,函数如下
年(日)返回日期的年份(范围在1000到9999)
月(日)返回日期中的月份数值
日(日)返回日期中的日期数值
小时(时间)返回时间的小时数(范围是0到23)
分钟(时间)返回时间的分钟数(范围是0到59)
第二(时间)返回时间的秒数(范围是0到59)
select year('2016-12-21');
日期计算,使用+- 运算符,数字后面的关键字为年,月,日,时,分,秒
select '2016-12-21'+interval 1 day;
日期格式化DATE_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()selectcurrent_time();
现在当前日期时间()select now();
类型转换函数
有投和转换两个函数
语法如下:
cast(value as type)
convert(value, type)
值表示要转换的值,键入表示目标类型
目标类型如下:
二进制二进制
字符型炭,可指定字符个数如炭(10)
日期日期
时间时间
日期时间型日期时间
浮点数小数
整数签署
无符号整数无符号
例SELECTCONVERT('125.83',SIGNED);SELECT CAST('125.83' AS signed);
流程控制
类似于python中的if语句,进行选择判断
case语法1:等值判断
说明:当值等于某个比较值的时候,对应的结果会被返回;如果所有的比较值都不相等则返回else的结果;如果没有else并且所有比较值都不相等则返回null
case 值when 比较值1 then 结果1when 比较值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 条件1then 结果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;