0

大家好 我正在尝试使用 C# 创建一个 asp.net 网页,以上传有关包含产品名称、描述、图像和产品编号的产品的详细信息。

protected void btnSubmit_Click(object sender, EventArgs e)
{
    string path = Server.MapPath("ProductsImages/");
    if (FileUpload1.HasFile)
    {
        string ext = Path.GetExtension(FileUpload1.FileName);
        if (ext == ".jpg" || ext == ".png")
        {
            FileUpload1.SaveAs(path + FileUpload1.FileName);
            string name = "~/ProductsImages/" + FileUpload1.FileName;
            string s = " insert into Products values('" + txtProductName.Text.Trim() + txtDescription.Text.Trim() + txtPrice.Text.Trim() + txtProductNumber.Text.Trim() + "','" + name + "')";


            SqlCommand cmd = new SqlCommand(s, con);
            con.Open();
            cmd.ExecuteNonQuery();
            con.Close();
            Response.Write("Your File Has Been Uploaded");
        }
        else 
        {
            Response.Write("You can upload only Jpg and png file");
        }
    }
    else 
    {
        Response.Write("Please Select an file To upload");
    }
}

但是当我开始调试时,它向我显示一个错误:SqlException:列名或提供的值的数量与表定义不匹配。

但是,我的数据库设计:数据类型 名称 nvarchar(50) 说明 nvarchar(50) 价格 nvarchar(50) 图像图像 Product_Number nvarchar(50)

我不知道哪里错了,代码还是数据库?

4

2 回答 2

1

在您正在创建 SQL 命令的行上放置一个断点。当断点被命中时,检查变量的值s。您的问题将变得很明显:您所做的只是将几个字段连接到一个字符串中。如果正确拆分它们,它应该可以工作。

另一方面,无论如何,您都不应该构建这样的查询。使用 SqlParameters 正确构建和转义您的查询。

于 2013-07-09T21:10:30.127 回答
0

您的插入查询缺少逗号。

它应该是:

string s = " insert into Products values('" + txtProductName.Text.Trim() + "', '" + txtDescription.Text.Trim() + "', " + txtPrice.Text.Trim() + ", " + txtProductNumber.Text.Trim())";

不过,最好用SqlParameters 来做。这是我的做法:

var queryInsert = "Insert Into Products Values (@productName, @productDescription, @productPrice, @productNumber)";

cmd.Parameters.AddWithValue("@productName", txtProductName.Text.Trim());
cmd.Parameters.AddWithValue("@productDescription", txtDescription.Text.Trim());

...你明白了。你会像我上面所做的那样为每个参数设置参数。

于 2013-07-09T21:11:53.920 回答