50.8. 函数

简介:

函数会返回数据,调用函数使用 select fun(),不能使用call调用,否则提示

		
mysql> call myfun();
ERROR 1305 (42000): PROCEDURE test.myfun does not exist			
		
		

下面做一个实验

CREATE TABLE `t` (
	`id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
	`n` INT(11) UNSIGNED NULL DEFAULT '0',
	PRIMARY KEY (`id`)
)
COLLATE='utf8_general_ci'
ENGINE=InnoDB
AUTO_INCREMENT=5;

CREATE DEFINER=`neo`@`%` FUNCTION `myfun`()
	RETURNS int(11)
	LANGUAGE SQL
	NOT DETERMINISTIC
	READS SQL DATA
	SQL SECURITY DEFINER
	COMMENT ''
BEGIN
	INSERT INTO t (n) VALUES(rand()*100);
	RETURN LAST_INSERT_ID();
END			
		
		
mysql> select myfun();
+---------+
| myfun() |
+---------+
|       9 |
+---------+
1 row in set, 2 warnings (0.07 sec)
		
		

50.8.1. TIMESTAMP TO ISO8601

			
USE `netkiller`;
DROP function IF EXISTS `timestamp_to_iso8601`;

DELIMITER $$
USE `netkiller`$$
CREATE DEFINER=`neo`@`db.netkiller.cn` FUNCTION `timestamp_to_iso8601`(dt timestamp) RETURNS varchar(24) CHARSET utf8
BEGIN

	RETURN DATE_FORMAT( CONVERT_TZ(dt, @@session.time_zone, '+00:00')  ,'%Y-%m-%dT%T.000Z'); 
    
END$$

DELIMITER ;
			
			

调用函数

			
mysql> select timestamp_to_iso8601(current_timestamp()) as iso8601;
+--------------------------+
| iso8601                  |
+--------------------------+
| 2017-12-07T07:21:22.000Z |
+--------------------------+
1 row in set (0.00 sec)
			
			





原文出处:Netkiller 系列 手札
本文作者:陈景峯
转载请与作者联系,同时请务必标明文章原始出处和作者信息及本声明。

目录
相关文章
|
4月前
|
存储 自然语言处理 数据处理
有效的函数(二)
有效的函数(二)
144 69
|
2月前
函数
一个源程序由多个函数组成。 C程序的执行从main()函数开始; 所有函数都是平行的; 函数分类;可以分为标准函数和自定义函数,还可以分为有参函数和无参函数。
|
5月前
|
存储 JavaScript 前端开发
使用函数
【8月更文挑战第26天】
18 1
|
7月前
|
算法 程序员 编译器
函数(2)
函数(2)
30 0
|
8月前
|
程序员 C语言 Python
函数—C(上)
函数—C(上)
61 0
|
8月前
|
开发工具 Windows
GetMessage()函数使用时的注意
GetMessage()函数使用时的注意
93 0
|
存储 编译器 C语言
C语言知识点之 函数
C语言知识点之 函数
66 0
|
程序员 C语言
函数(1)
函数(1)
|
算法 编译器 API
8.函数
8.函数
80 0