我们的aspx页面上有一个表单,其中包含许多文本框。我们想在我们的sql server数据库中更新几个表,并在这些文本框中输入值,但是如果任何一个文本框都留空,我们希望保留该列的数据,因为它现在赢了。 t接受空值。
如果所有文本框都已填充,它将正常运行,否则,我们会收到错误消息: 输入字符串的格式不正确。
单击提交按钮时触发的代码:
protected void buttonClicked(object sender, EventArgs e)
{
string CS = ConfigurationManager.ConnectionStrings["G4StowawaysConnectionString"].ConnectionString;
SqlConnection conn = new SqlConnection(CS);
conn.Open();
String sql5 = "" ;
if (!@BalanceOutstanding.Text.Equals(null) | !@Comments.Text.Equals(null))
{
sql5 += "UPDATE BookingView SET ";
if (!@BalanceOutstanding.Text.Equals(null))
{
sql5 += " [Balance_Outstanding]=@BalanceOutstanding,";
}
if (!@Comments.Text.Equals(null))
{
sql5 += " [Comments]=@Comments ";
}
sql5 += "WHERE [Booking_Ref] = @BookingRef;";
}
if (!@BoatID.Text.Equals(null) | !@SpecialRequests.Text.Equals(null) | !@LeadPassenger.Text.Equals(null) | !@Duration.Text.Equals(null) | !@Pets.Text.Equals(null) | !@Children.Text.Equals(null) | !@Passengers.Text.Equals(null))
{
sql5 += "UPDATE vBoat_Booking SET";
if (!@BoatID.Text.Equals(null))
{
sql5 += " [BoatID]=@BoatID,";
}
if (!@SpecialRequests.Text.Equals(null))
{
sql5 += " [Special_Request]=@SpecialRequests,";
}
if (!@LeadPassenger.Text.Equals(null))
{
sql5 += " [Lead_PassengerID]=@LeadPassenger,";
}
if (!@Duration.Text.Equals(null))
{
sql5 += " [Duration_In_Hours]=@Duration,";
}
if (!@Pets.Text.Equals(null))
{
sql5 += " [Number_of_pets]=@Pets,";
}
if (!@Children.Text.Equals(null))
{
sql5 += " [Number_of_children]=@Children,";
}
if (!@Passengers.Text.Equals(null))
{
sql5 += " [Number_of_passengers]=@Passengers ";
}
sql5 += "WHERE [Booking_Ref] = @BookingRef;";
}
SqlCommand cmd2 = new SqlCommand(sql5, conn);
//add our parameters to our command object
cmd2.Parameters.AddWithValue("@BookingRef", Convert.ToInt32(BookingRef.Text));
cmd2.Parameters.AddWithValue("@BoatID", Convert.ToInt32(BoatID.Text));
cmd2.Parameters.AddWithValue("@LeadPassenger", Convert.ToInt32(LeadPassenger.Text));
cmd2.Parameters.AddWithValue("@Duration", Convert.ToInt32(Duration.Text));
cmd2.Parameters.AddWithValue("@Pets", Convert.ToInt32(Pets.Text));
cmd2.Parameters.AddWithValue("@Children", Convert.ToInt32(Children.Text));
cmd2.Parameters.AddWithValue("@Passengers", Convert.ToInt32(Passengers.Text));
cmd2.Parameters.AddWithValue("@SpecialRequests", SpecialRequests.Text);
cmd2.Parameters.AddWithValue("@BalanceOutstanding", Convert.ToInt32(BalanceOutstanding.Text));
cmd2.Parameters.AddWithValue("@Comments", Comments.Text);
cmd2.ExecuteNonQuery();
conn.Close();
}
答案 0 :(得分:0)
您在if块中使用尾随逗号,并且应该使用前导逗号。除了添加到动态SQL的第一个字段。您可以使用bool来确定代码段是否需要前导逗号。
另一种选择是在存储过程中创建动态SQL。如果这样做,您将希望使用与您在C#代码中使用它们非常类似的参数。使用sp_executesql而不是exec。这允许您定义参数并为这些参数赋值。转到here以查看使用带参数的sp_executesql的示例。