MySQL 函数

语法:

delimiter $$
create function 函数名称(参数列表) returns 返回类型
begin
sql语句
end
$$
delimiter ;

示例:

delimiter $$
create function py_trim(str varchar(100)) returns varchar(100)
begin
declare x varchar(100);
set x=ltrim(rtrim(str));
return x;
end
$$
delimiter ;

查看创建好的函数

  • 所有函数存储在mysql数据库下的proc表中

  • 说明:存储过程与函数都存储在proc表中,区别在type字段,函数的type字段为 FUNCTION

  • 查看python数据库中的函数

    select name,type from mysql.proc where db='python';

调用函数

语法:

select 函数名称(参数列表);
mysql> select py_trim(' ss')
    -> ;
+----------------+
| py_trim(' ss') |
+----------------+
| ss             |
+----------------+
1 row in set (0.00 sec)

MySQL 提供类大量的内置函数

字符串函数

查看字符的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');

日期时间函数

获取子值,值为整数类型,函数如下

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();



MySQL 内置函数大全 同学们自行学习

数据库基础 all right reserved,powered by Gitbook文件修订时间: 2018-05-09 17:57:14