我收到了一个错误:
变量名称'@GCSSalesPerson' 已经宣布。变量 名称在查询中必须是唯一的 批处理或存储过程。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Configuration;
public partial class Customer : System.Web.UI.Page
{
protected void
Page_Load(object sender, System.EventArgs e)
{
lblErrMsg.Visible = true;
}
protected void btnInsert_Click1(object sender, EventArgs e)
{
SqlConnection thisConnection = new SqlConnection(ConfigurationManager.ConnectionStrings["GSI2ConnectionString"].ConnectionString);
//Create Command object
SqlCommand nonqueryCommand = thisConnection.CreateCommand();
try
{
// Open Connection
thisConnection.Open();
// Create INSERT statement with named parameters
nonqueryCommand.CommandText = "INSERT INTO Customers
(ChurchName,ContactName,ContactPhoneNumber,ContactCellNumber,ContactEmail,
FaxNumber,ChurchAddress,ChurchAddress2,ChurchCity,ChurchState,ChurchZipCode,
Notes,GCSSalesPerson)
VALUES
(@ChurchName,@ContactName,@ContactPhoneNumber,@ContactCellNumber,@ContactEmail,
@FaxNumber,@ChurchAddress,@ChurchAddress2,@ChurchCity,@ChurchState,@ChurchZipCode,
@Notes,@GCSSalesPerson)";
// Add Parameters to Command Parameters collection
nonqueryCommand.Parameters.Add("@ChurchName", System.Data.SqlDbType.VarChar, 70);
nonqueryCommand.Parameters.Add("@ContactName", System.Data.SqlDbType.VarChar, 70);
nonqueryCommand.Parameters.Add("@ContactPhoneNumber", System.Data.SqlDbType.VarChar, 12);
nonqueryCommand.Parameters.Add("@ContactCellNumber", System.Data.SqlDbType.VarChar, 12);
nonqueryCommand.Parameters.Add("@ContactEmail", System.Data.SqlDbType.VarChar, 50);
nonqueryCommand.Parameters.Add("@FaxNumber", System.Data.SqlDbType.VarChar, 12);
nonqueryCommand.Parameters.Add("@ChurchAddress", System.Data.SqlDbType.VarChar, 70);
nonqueryCommand.Parameters.Add("@ChurchAddress2", System.Data.SqlDbType.VarChar, 50);
nonqueryCommand.Parameters.Add("@ChurchCity", System.Data.SqlDbType.VarChar, 50);
nonqueryCommand.Parameters.Add("@ChurchState", System.Data.SqlDbType.VarChar, 3);
nonqueryCommand.Parameters.Add("@ChurchZipCode", System.Data.SqlDbType.VarChar, 6);
nonqueryCommand.Parameters.Add("@Notes", System.Data.SqlDbType.VarChar, 7800);
nonqueryCommand.Parameters.Add("@ContactEmail", System.Data.SqlDbType.VarChar, 50);
nonqueryCommand.Parameters.Add("@GCSSalesPerson", System.Data.SqlDbType.VarChar, 50);
nonqueryCommand.Parameters["@ChurchName"].Value = TextBox1.Text;
nonqueryCommand.Parameters["@ContactName"].Value = TextBox2.Text;
nonqueryCommand.Parameters["@ContactPhoneNumber"].Value = TextBox3.Text;
nonqueryCommand.Parameters["@ContactCellNumber"].Value = TextBox4.Text;
nonqueryCommand.Parameters["@ContactEmail"].Value = TextBox5.Text;
nonqueryCommand.Parameters["@FaxNumber"].Value = TextBox6.Text;
nonqueryCommand.Parameters["@ChurchAddress"].Value = TextBox7.Text;
nonqueryCommand.Parameters["@ChurchAddress2"].Value = TextBox8.Text;
nonqueryCommand.Parameters["@ChurchCity"].Value = TextBox9.Text;
nonqueryCommand.Parameters["@ChurchState"].Value = DropDownList1.Text;
nonqueryCommand.Parameters["@ChurchZipCode"].Value = TextBox11.Text;
// nonqueryCommand.Parameters["@Notes"].Value = TextArea1.Text;
nonqueryCommand.Parameters["@GCSSalesPerson"].Value = DropDownList2.Text;
nonqueryCommand.ExecuteNonQuery();
}
catch (SqlException ex)
{
// Display error
lblErrMsg.Text = ex.ToString();
lblErrMsg.Visible = true;
}
finally
{
// Close Connection
TextBox1.Text = "";
TextBox2.Text = "";
TextBox3.Text = "";
TextBox4.Text = "";
TextBox5.Text = "";
TextBox6.Text = "";
TextBox7.Text = "";
TextBox8.Text = "";
TextBox9.Text = "";
TextBox11.Text = "";
thisConnection.Close();
}
}
}
答案 0 :(得分:5)
您确定错误消息未指定@ContactEmail
吗?
您正在@ContactEmail
添加nonqueryCommand
两次:
nonqueryCommand.Parameters.Add("@ContactEmail", System.Data.SqlDbType.VarChar, 50);
这与该错误消息完全匹配。
答案 1 :(得分:0)
您在查询中指定了两次@ContactEmail,并且还添加了命令
nonqueryCommand.Parameters["@ContactEmail"].Value = TextBox5.Text;