P80 存储函数的创建与调用

2.存储函数的创建与调用

在这里插入图片描述

#举例1:创建存储函数,名称为email_by_name(),参数定义为空,
#该函数查询Abel的email,并返回,数据类型为字符串型。

DELIMITER //

CREATE FUNCTION email_by_name()
RETURNS VARCHAR(25)
        DETERMINISTIC
        CONTAINS SQL
        READS SQL DATA
BEGIN
	RETURN (SELECT email
	       FROM employees
	       WHERE last_name='Abel');

END//

DELIMITER ;

#调用
SELECT email_by_name();

#举例2:创建存储函数,名称为email_by_id(),参数传入emp_id,
#该函数查询emp_id的email,并返回,数据类型为字符串型。
#创建函数前,执行此语句,保证函数的创建会成功

SET GLOBAL log_bin_trust_function_creators = 1;

DELIMITER //

CREATE FUNCTION email_by_id(emp_id INT)
RETURNS VARCHAR(25)

BEGIN
	RETURN(SELECT email FROM employees WHERE employee_id=emp_id);

END //

DELIMITER ;

#调用
SELECT email_by_id(101);

#方式2:
SET @emp_id=102;
SELECT email_by_id(@emp_id);

#举例3:创建存储函数count_by_id(),参数传入dept_id,
#该函数查询dept_id部门的员工人数,并返回,数据类型为整型。

SET GLOBAL log_bin_trust_function_creators = 1;

DELIMITER //

CREATE FUNCTION count_by_id(dept_id INT)
RETURNS INT

BEGIN
	RETURN(SELECT COUNT(*)FROM employees WHERE department_id=dept_id);

END //

DELIMITER ;

#调用
SET @dept_id=30;
SELECT count_by_id(@dept_id);

3.对比存储函数与存储过程

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值