MySQL命令大全 (6)

 存储过程与存储函数的区别:存储过程:可以有0个返回,也可以有多个返回,适合做批量插入、批量更新,存储函数:有且仅有1 个返回,适合做处理数据后返回一个结果

1.创建语法

CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型 BEGIN 函数体 END

 2.调用语法

SELECT 函数名(参数列表);

3.无参数返回

例1:返回公司的员工个数

USE myemployees; DELIMITER // CREATE FUNCTION myf1() RETURNS INT BEGIN DECLARE c INT DEFAULT 0; #定义局部变量 SELECT COUNT(*) INTO c #赋值 FROM employees; RETURN c; END //

SELECT myf1();

4.有参数返回

例1:根据员工名,返回它的工资

DELIMITER // CREATE FUNCTION myf2(empName VARCHAR(20)) RETURNS DOUBLE BEGIN SET @sal=0; #定义用户变量 SELECT salary INTO @sal #赋值 FROM employees WHERE last_name = empName; RETURN @sal; END //

SELECT myf2('Kochhar'); SELECT @sal;

 5.查看函数

SHOW CREATE FUNCTION myf3;

 6.删除函数

DROP FUNCTION myf3;

储过程:可以有0个返回,也可以有多个返回,适合做批量插入、批量更新

存储函数:有且仅有1 个返回,适合做处理数据后返回一个结果

CREATE FUNCTION 函数名(参数列表) RETURNS 返回类型 BEGIN 函数体 ENDCopy to clipboardErrorCopied

参数列表 包含两部分:参数名,参数类型

函数体:

肯定会有return语句,如果没有会报错 如果return语句没有放在函数体的最后也不报错,但不建议

函数体中仅有一句话,则可以省略begin end

使用 delimiter语句设置结束标记

SELECT 函数名(参数列表);Copy to clipboardErrorCopied

返回公司的员工个数

USE myemployees; DELIMITER // CREATE FUNCTION myf1() RETURNS INT BEGIN DECLARE c INT DEFAULT 0; #定义局部变量 SELECT COUNT(*) INTO c #赋值 FROM employees; RETURN c; END //Copy to clipboardErrorCopied SELECT myf1();Copy to clipboardErrorCopied

根据员工名,返回它的工资

DELIMITER // CREATE FUNCTION myf2(empName VARCHAR(20)) RETURNS DOUBLE BEGIN SET @sal=0; #定义用户变量 SELECT salary INTO @sal #赋值 FROM employees WHERE last_name = empName; RETURN @sal; END //Copy to clipboardErrorCopied SELECT myf2('Kochhar'); SELECT @sal;Copy to clipboardErrorCopied

根据部门名,返回该部门的平均工资

DELIMITER // CREATE FUNCTION myf3(deptName VARCHAR(20)) RETURNS DOUBLE BEGIN DECLARE sal DOUBLE ; SELECT AVG(salary) INTO sal FROM employees e JOIN departments d ON e.department_id = d.department_id WHERE d.department_name=deptName; RETURN sal; END //Copy to clipboardErrorCopied SELECT myf3('IT');Copy to clipboardErrorCopied SHOW CREATE FUNCTION myf3;Copy to clipboardErrorCopied DROP FUNCTION myf3;Copy to clipboardErrorCopied

创建函数,实现传入两个float,返回二者之和

DELIMITER // CREATE OR REPLACE FUNCTION myf3(num1 FLOAT,num2 FLOAT) RETURNS FLOAT(3,1) BEGIN DECLARE SUM FLOAT(3,1) DEFAULT 0; SET SUM=num1+num2; RETURN SUM; END //Copy to clipboardErrorCopied SELECT myf3(15.5,15.3); --> 30.8

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zydfzg.html