首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql存储函数返回total

mysql存储函数返回total
EN

Stack Overflow用户
提问于 2021-01-29 06:13:39
回答 1查看 58关注 0票数 0

我有一个包含employees的mysql表,每个employee的列分别为surnameworkhours。我正在尝试创建一个存储函数,它接受一个字母作为输入,并返回其姓氏从输入字母开始的所有员工的工作时间总和。.This基本上是一项简单的任务,但我是一个完全的sql初学者,我需要您的帮助。

我尝试过的:

代码语言:javascript
复制
CREATE FUNCTION sumOfTotalSickHours(letter CHAR(1))
RETURNS DOUBLE DETERMINISTIC
BEGIN
     DECLARE total DOUBLE DEFAULT 0
     SELECT SUM(sickleavehours) INTO total
        FROM employee where lastName LIKE '@letter%'
     RETURN total

END

使用上面的代码,我得到了一个语法错误,因为我不知道如何正确地编写查询。

EN

回答 1

Stack Overflow用户

发布于 2021-01-29 06:19:09

首先,每条语句都需要以分号(;)结尾。

请务必阅读https://dev.mysql.com/doc/refman/8.0/en/stored-programs-defining.html以了解如何在定义存储程序时使用分隔符。

此外,要引用输入变量,请不要在内部加上引号。

不要使用@letter,因为使用@符号的变量与不使用符号的变量不同。

举个例子:

代码语言:javascript
复制
CREATE FUNCTION sumOfTotalSickHours(letter CHAR(1))
RETURNS DOUBLE DETERMINISTIC
BEGIN
     DECLARE total DOUBLE DEFAULT 0;
     SELECT SUM(sickleavehours) INTO total
        FROM employee where lastName LIKE CONCAT(letter, '%');
     RETURN total;

END
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65945990

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档