MySqlCommand调用函数

Ive*_*aev 3 .net mysql function call return-value

我正在使用MySQL连接器.

using (MySqlConnection connection = new MySqlConnection("..."))
{
    connection.Open();
    MySqlCommand command = new MySqlCommand();
    command.Connection = connection;
    command.CommandType = CommandType.StoredProcedure;
    command.CommandText = "FN_NEW";
    command.Parameters.AddWithValue("P_SESSION_ID", sessionId);
    command.Parameters.AddWithValue("P_NAME", deckName);
    object result = command.ExecuteScalar(); // returns NULL !!!!!!!!!
    return Json(result);
}
Run Code Online (Sandbox Code Playgroud)

由于某种原因,返回的valus为null.我使用正确的CommandType吗?

我如何从.NET调用MySQL函数?

最终的工作版本是:

using (MySqlConnection connection = new    MySqlConnection(GetConnectionString().ConnectionString))
    {
        connection.Open();
        MySqlCommand command = new MySqlCommand();
        command.Connection = connection;
        command.CommandType = CommandType.StoredProcedure;
        command.CommandText = "FN_NEW";
        command.Parameters.AddWithValue("P_SESSION_ID", sessionId);
        command.Parameters.AddWithValue("P_NAME", deckName);
        MySqlParameter returnParam = command.Parameters.Add("@RETURN_VALUE", MySqlDbType.Int32);
        returnParam.Direction = System.Data.ParameterDirection.ReturnValue;            
        command.ExecuteNonQuery();
        NewDeckReturnCode result = (NewDeckReturnCode)returnParam.Value;
        return Json(result);
    }
Run Code Online (Sandbox Code Playgroud)

Chr*_*ter 5

使用参数方向为命令添加其他参数:

System.Data.ParameterDirection.ReturnValue;
Run Code Online (Sandbox Code Playgroud)

并使用

command.ExecuteNonQuery(); 
Run Code Online (Sandbox Code Playgroud)

然后在调用ExecuteNonQuery之后从返回值参数中检索返回值.