错误代码1046:未选择数据库

roc*_*cky 4 mysql stored-procedures

我在MySQl Workbench上编写了一个存储过程(sp_archivev3),如下所示.基本上,将值从一个数据库插入另一个数据库.

-- --------------------------------------------------------------------------------
-- Routine DDL
-- Note: comments before and after the routine body will not be stored by the server
-- --------------------------------------------------------------------------------
DELIMITER $$

CREATE DEFINER=`MailMe`@`%` PROCEDURE `sp_archivev3`()
BEGIN

INSERT INTO 
     send.sgev3_archive(a_bi,
                        b_vc,
                        c_int,
                        d_int,
                        e_vc,
                        f_vc,
                        g_vc,
                        h_vc,
                        i_dt,
                        j_vc,
                        k_vc,
                        l_vc,
                        m_dt,
                        n_vch,
                        o_bit)
SELECT     a_bi,
           b_vc,
           c_int,
           d_int,
           e_vc,
           f_vc,
           g_vc,
           h_vc,
           i_dt,
           j_vc,
           k_vc,
           l_vc,
           m_dt,
           n_vch,
           o_bit

FROM   send.sgev3

WHERE m_dt BETWEEN  '2014-06-09' AND CURDATE();


END
Run Code Online (Sandbox Code Playgroud)

当我运行时call sp_archivev3();,出现错误,错误代码为1046:未选择数据库通过在侧栏的SCHEMAS列表中双击其名称来选择要使用的默认数据库.

请让我知道我的存储过程有什么问题.

spe*_*593 13

问题是MySQL不知道sp_archivev3应该执行哪个命名过程; MySQL不知道要查看哪个数据库.(存储程序是特定数据库中的对象,就像表是特定数据库中的对象一样.)

使用USE语句指定当前数据库:

use mydatabase;
call sp_archivev3();
Run Code Online (Sandbox Code Playgroud)

或者使用数据库名称限定程序:

call mydatabase.sp_archivev3();
Run Code Online (Sandbox Code Playgroud)