难以从带有参数的存储过程填充数据网格

本文关键字:填充 存储过程 数据 数据网 网格 参数 | 更新日期: 2023-09-27 17:49:14

protected DataTable RetrieveAlumni2()
        {
            {
                MySqlConnection con = new MySqlConnection("server=100.0.0.0;user id=id;password=pass;database=db;persistsecurityinfo=True");
                MySqlCommand cmd = new MySqlCommand("get_alumni_by_city", con);
                MySqlDataAdapter da = new MySqlDataAdapter(cmd);
                DataTable dt = new DataTable();
                try
                {
                    string city = textBox1.Text;
                    con.Open();
                    cmd.CommandType = CommandType.StoredProcedure;
                    cmd.Parameters.AddWithValue("@city", SqlDbType.VarChar).Value = city;
                    da.SelectCommand = cmd;
                    cmd.ExecuteNonQuery();
                    da.Fill(dt);
                    dataGridView1.DataSource = dt;
                }
                catch (System.Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
                finally
                {
                    cmd.Dispose();
                    con.Close();
                }
                return dt;
            }
        }

给出错误:

"输入字符串格式不正确"

City在mysql服务器中为varchar。

难以从带有参数的存储过程填充数据网格

你试过吗?

cmd.Parameters.AddWithValue("@city","" + city + "");

检查存储过程中@city的类型。如果它与您输入的内容不匹配,它将拒绝它