mysql 等待函数_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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值