我正在使用poco库版本1.4.6
我想让make程序连接数据库,调用存储过程并获取参数。
首先,我选择这样的值。
conn.Connect(host, user, password, db);
Poco::Data::Session* session = conn.Ptr();
int myNum;
std::string myStr;
*session << "SELECT `my_number`, `my_string` FROM `my_table`;",
Poco::Data::into(myNum),
Poco::Data::into(myStr),
Poco::Data::now;
可以。
我想调用存储过程并获取输出参数值。所以写得像这样。
// `my_sp` was simple stored procedure like this.
// `my_sp`(in inum int, in istr varchar(50), out onum int, out ostr varchar(50))
// SET onum = inum;
// SET ostr = istr;
int inNum, outNum;
std::string inStr, outStr;
*session << "CALL `my_sp`(?,?,?,?);",
Poco::Data::use(inNum),
Poco::Data::use(inStr),
Poco::Data::into(outNum),
Poco::Data::into(outStr),
Poco::Data::now;
但它不可用。
我试过了。
*session << "CALL `my_sp`(1234, \'abcd\', @o_num, @o_str);",
Poco::Data::now;
*session << "SELECT @o_num;",
Poco::Data::into(outNum),
Poco::Data::now;
//*session << "SELECT @o_num, @o_str;",
// Poco::Data::into(outNum),
// Poco::Data::into(outStr),
// Poco::Data::now;
我可以通过选择输出号码。但我无法摆脱弦乐。如果我选择outStr,则抛出异常。
[MySQL]: [Comment]: mysql_stmt_fetch error [mysql_stmt_error]: [mysql_stmt_errno]: 0 [mysql_stmt_sqlstate]: 00000 [statemnt]: SELECT @o_num, @o_str;
为什么抛出异常?我不明白。因为我不会说英语。
我试着找到像我这样的另一个问题。但其他用户与我不同。
我认为原因是我不擅长英语。很难学习poco文件。
我想使用存储过程并获取输出参数。
请帮助我!
答案 0 :(得分:0)
1.4.x不支持存储过程。您应该使用1.5.x版本和Data :: ODBC后端来获得完整的存储过程I / O支持。