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服务器版本,以便使用正确的语法
这里可能有什么问题?
嗯,我不是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";