.net - 找不到 mysql .net 更新存储过程

标签 .net mysql stored-procedures

我正在使用 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/

相关文章:

php - 在php5中,如何在具有分隔符的脚本中使用mysql_execute

entity-framework - Entity Framework 代码优先和存储过程

sql - 如何在 Oracle 的过程中创建表?

.net - ASP.net 3.0 的 MVC 框架?

.net - FTPWebRequest上传文件只会上传两个文件!

.net - 保留内存是否会导致内存不足异常

在表值函数中使用#table/Temp 表的 SQL

.NET 反射 : Detecting IEnumerable<T>

php - 没有错误消息的 PDO 问题

mysql - 一个表中的多个数据集或在表中显示不同的值 (SSRS)