我正在使用 mysql 和 .net Framework 4.0 。我的数据库中有存储过程。我的存储过程调用是:
public DataTable addProductMenu(int myid, string itemname)
{
MySqlConnection connection = new MySqlConnection(connectionString);
MySqlDataAdapter adapt = new MySqlDataAdapter("updateProductMenu", connection);
adapt.SelectCommand.CommandType = CommandType.StoredProcedure;
adapt.SelectCommand.Parameters.AddWithValue("myid", myid);
adapt.SelectCommand.Parameters.AddWithValue("itemname", itemname);
DataTable dt = new DataTable();
adapt.Fill(dt);
adapt = null;
if (dt != null && dt.Rows.Count != 0)
{
return dt;
}
else
{
return null;
}
}
当我在数据库中使用插入、选择命令但不更新时,代码可以正常工作。我在 mysql 查询浏览器中测试了我的程序,它工作正常。
还尝试了此代码来更新查询
public DataTable updateProductMenu(int myid, string itemname)
{ //Veritabanından ürün menüsündeki başlığı güncelle
MySqlConnection cnx = new MySqlConnection(connectionString);
MySqlDataAdapter adapter = new MySqlDataAdapter();
string cmdText = "updateProductMenu";
MySqlCommand cmd = new MySqlCommand(cmdText, cnx);
cmd.CommandType = CommandType.StoredProcedure;
MySqlParameter param;
param = new MySqlParameter("?myid", MySqlDbType.Int32);
param.Value = myid;
param.Direction = ParameterDirection.Input;
cmd.Parameters.Add(param);
param = new MySqlParameter("?itemname", MySqlDbType.VarChar);
param.Value = itemname;
param.Direction = ParameterDirection.Input;
cmd.Parameters.Add(param);
adapter.SelectCommand = cmd;
DataTable dt = new DataTable();
adapter.Fill(dt);
adapter = null;
if (dt != null && dt.Rows.Count != 0)
{
return dt;
}
else
{
return null;
}
}
两者都有错误
Procedure or function '`updateProductMenu`' cannot be found in database '`mydatabase`'.
已添加-----------------------------------------------------
该用户拥有所有权限。我又检查了一下。
这是我在 web.config 文件中的连接字符串...:
<add name="maktesConn" connectionString="Server = myserver; Port =3306; Database =mydatabase; Uid =mysqlsanatkar; Pwd =*123qsanatq*/;" />
......这是我的类(class)的一部分......:
public class Mimages
{
private string connectionString;
public Mimages()
{
connectionString = ConfigurationManager.ConnectionStrings["maktesConn"].ToString();
}
这是我的存储过程的一部分
DROP PROCEDURE IF EXISTS mydatabase.updateProductMenu $$
CREATE PROCEDURE mydatabase.updateProductMenu (myid INT, itemname VARCHAR(60))
BEGIN
....
最佳答案
您是说您可以使用相同的代码调用其他存储过程或仅选择和插入命令吗?
您是否检查过数据库名称和存储过程名称的上限?根据设置,MySql 会将名称转换为小写并区分大小写。
检查数据库当前的安全性?
关于.net - 找不到 mysql .net 更新存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7581421/