首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql中的Create PROCEDURE错误

mysql中的Create PROCEDURE错误
EN

Stack Overflow用户
提问于 2014-08-13 22:44:45
回答 2查看 37关注 0票数 0

我正在尝试在mysql中执行查询。因此,当我运行时,我接收到:

代码语言:javascript
复制
Error Code: 1304. PROCEDURE ander already exists

我试图用@定义变量"a“,但结果是相同的-错误代码: 1304。实际上,当我执行SELECT语句时是正确的。那么,我的错误在哪里呢?

代码语言:javascript
复制
DELIMITER //
CREATE PROCEDURE ander() 

BEGIN


DECLARE a int ;
SET a=1;


  WHILE a < 20
    DO

    SELECT 
    (SUM(price) + SUM(delivery_price)) as total_sum,
    COUNT(`id`) AS total_cnt,
    market_id,
    `date`,
    COUNT(`user_id`) AS total_users
    FROM orders 
    WHERE 
    (`date`>='2014-08-01 00:00:00' - INTERVAL a DAY) AND ( `date`<='2014-08-01   23:59:59' - INTERVAL a DAY)

    GROUP BY market_id;


    SET a=a+1;


    END WHILE;

END//
DELIMITER ; 

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2014-08-13 22:46:54

在开头添加以下内容:

代码语言:javascript
复制
DROP PROCEDURE ander;

所以你应该有:

代码语言:javascript
复制
DROP PROCEDURE ander;

CREATE PROCEDURE ander() 

BEGIN


DECLARE a int ;
SET a=1;


  WHILE a < 20
    DO

    SELECT 
    (SUM(price) + SUM(delivery_price)) as total_sum,
    COUNT(`id`) AS total_cnt,
    market_id,
    `date`,
    COUNT(`user_id`) AS total_users
    FROM orders 
    WHERE 
    (`date`>='2014-08-01 00:00:00' - INTERVAL a DAY) AND ( `date`<='2014-08-01   23:59:59' - INTERVAL a DAY)

    GROUP BY market_id;


    SET a=a+1;


    END WHILE;

END//
DELIMITER ; 
票数 1
EN

Stack Overflow用户

发布于 2014-08-13 22:47:04

每个mysql过程都存储在数据库中(基本上它是一个数据库对象)

首先需要使用语法drop

代码语言:javascript
复制
DROP PROCEDURE ander

文档:

  • http://dev.mysql.com/doc/refman/5.0/en/drop-procedure.html
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25289241

复制
相关文章

相似问题

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