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)
| 归档时间: |
|
| 查看次数: |
34938 次 |
| 最近记录: |