MySQL/C#存储过程不返回值
问题描述:
我一直无法从存储过程向C#应用程序返回值。该过程在MySql工作台中返回一个值,但不是C#。在C#输出中没有值被显示。下面的过程和方法调用我下面包括:MySQL/C#存储过程不返回值
/*
CREATE PROCEDURE `proc_FindChildID` (OUT CID VARCHAR(6))
BEGIN
SELECT MAX(ChildID) INTO @CID FROM Child;
SET @CID = SUBSTRING(@CID FROM 1);
SELECT @CID;
END //
*/
public bool callProcedure()
{
if (this.OpenConnection() == true)
{
MySqlCommand command = connection.CreateCommand();
command.CommandType = CommandType.StoredProcedure;
command.CommandText = "proc_FindChildID";
command.Parameters.Add(new MySqlParameter("@CID", MySqlDbType.VarChar, 6));
command.Parameters["@CID"].Direction = ParameterDirection.Output;
command.ExecuteNonQuery();
string t_return = command.Parameters["@CID"].Value.ToString();
Console.WriteLine("ID:" + t_return);
this.CloseConnection();
return true;
}
else
{
return false;
}
}
答
我不知道的MySqlCommand但通常如果是MSSQL我会叫object o = command.ExecuteScalar();
而不是command.ExecuteNonQuery();
来获取值。
你先生是个天才!这解决了我的问题。非常感谢你! – apoclyps 2013-03-27 23:31:59
标记为答案,如果它解决了:)不客气 – Xelom 2013-03-27 23:55:50