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

时间:2014-06-12 17:35:57

标签: 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

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

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

1 个答案:

答案 0 :(得分:11)

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

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

use mydatabase;
call sp_archivev3();

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

call mydatabase.sp_archivev3();