MySql存储过程没有从asp.net中执行

本文关键字:net 执行 asp 存储过程 MySql | 更新日期: 2023-09-27 18:16:27

我能够执行MySQL sp.在服务器上它工作得很好,但是当从asp.net调用时它不能正常工作。下面是存储过程:

CREATE PROCEDURE `GetCategoryForBackLinkID`(IN BLID int, OUT CatID int)
BEGIN
        SELECT CategoryID INTO CatID FROM backlink where BackLinkID = BLID;
END
下面是asp.net代码
MySqlCommand cmd1 = new MySqlCommand("GetCategoryForBackLinkID");
MySqlConnection con1 = new MySqlConnection();
//ConnectionStringSettings mySetting = ConfigurationManager.ConnectionStrings["linkbuilding1Entities3"];
con1.ConnectionString = "server=67.227.183.117;User Id=rammu1;Pwd=eframmu1;database=linkbuilding1;Persist Security Info=True";
cmd1.Connection = con1;
using (cmd1.Connection)
{
     cmd1.Connection.Open();
     MySqlParameter returnParameter1 = cmd1.Parameters.Add("BLID", MySqlDbType.Int16);
     returnParameter1.Direction = ParameterDirection.Input;
     returnParameter1.Value = maximumbacklinid;
     MySqlParameter returnParameter2 = cmd1.Parameters.Add("CatID", MySqlDbType.Int16);
     returnParameter2.Direction = ParameterDirection.Output;
     cmd1.ExecuteNonQuery();                   
     CategID = (Int16)returnParameter2.Value;
我得到的错误是

你的SQL语法有错误;查看手册对应于MySQL服务器版本,以便使用正确的语法

这里可能有什么问题?

MySql存储过程没有从asp.net中执行

,我不是100%确定,但看起来你需要传递你的CommandType属性,如;

cmd1.CommandType = CommandType.StoredProcedure;

由于您使用存储过程,因此该属性默认为Text。这就是为什么你的程序认为你的"GetCategoryForBackLinkID"字符串是一个有效的SQL查询,而不是一个存储过程。

当您将CommandType属性设置为StoredProcedure时,您应该将CommandText属性设置为存储过程的名称。的方法之一时执行此存储过程执行方法。

using(MySqlConnection con1 = new MySqlConnection(connString))
using(MySqlCommand cmd1 = con.CreateCommand())
{
   cmd1.CommandType = CommandType.StoredProcedure;
   // Add your parameter values.
   cmd1.ExecuteNonQuery();
   CategID = (int)returnParameter2.Value;
}

在你的连接字符串一个关键字是错误的写数据源不是数据库那里

"server=67.227.183.117;User Id=rammu1;Pwd=eframmu1;Data Source=linkbuilding1;Persist Security Info=True";