[英]Updating SQL Server database with values from textboxes using stored procedure
我们有一个aspx页面,其中有多个文本框。 我们要获取输入到这些文本框中的数据,并使用它们更新我们的SQL Server数据库。 但是,如果任何文本框都留为空白,那么我们希望数据保持原样。
我们编写了以下存储过程来执行更新:
ALTER PROCEDURE pr_updateBooking
(
@BookingRef INT,
@BoatID INT,
@LeadPassenger INT,
@StartDate Date,
@Duration INT,
@Pets INT,
@Children INT,
@Passengers INT,
@SpecialRequests VARCHAR(255),
@BalanceOutstanding NUMERIC(12, 2),
@Comments VARCHAR(50)
)
AS
DECLARE @error INT
UPDATE BookingView
SET Balance_Outstanding = @BalanceOutstanding,
Comments = @Comments
WHERE Booking_Ref = @BookingRef
UPDATE vBoat_Booking
SET BoatID = @BoatID, Lead_PassengerID = @LeadPassenger,
Start_Date = @StartDate, Duration_In_hours = @Duration,
Number_of_pets = @Pets, Number_of_children = @Children,
Number_of_passengers = @Passengers
WHERE Booking_Ref = @BookingRef
SET @error = @@error
IF @error <> 0
RETURN 99
ELSE
RETURN 0
这是在我们的aspx页面上单击“提交”按钮时将运行的C#代码
protected void buttonClicked(object sender, EventArgs e)
{
string CS = ConfigurationManager.ConnectionStrings["G4StowawaysConnectionString"].ConnectionString;
SqlConnection conn = new SqlConnection(CS);
conn.Open();
SqlCommand cmd2 = new SqlCommand("pr_updateBooking", conn);
cmd2.CommandType = CommandType.StoredProcedure;
// add our parameters to our command object
cmd2.Parameters.Add("@BookingRef", SqlDbType.Int).Value = BookingRef.Text;
cmd2.Parameters.Add("@BoatID", SqlDbType.Int).Value = BoatID.Text;
cmd2.Parameters.Add("@LeadPassenger", SqlDbType.Int).Value = LeadPassenger.Text;
cmd2.Parameters.Add("@StartDate", SqlDbType.Date).Value = StartDate.Text;
cmd2.Parameters.Add("@Duration", SqlDbType.Money).Value = Duration.Text;
cmd2.Parameters.Add("@Pets", SqlDbType.Int).Value = Pets.Text;
cmd2.Parameters.Add("@Children", SqlDbType.Int).Value = Children.Text;
cmd2.Parameters.Add("@Passengers", SqlDbType.Int).Value = Passengers.Text;
cmd2.Parameters.Add("@SpecialRequests", SqlDbType.VarChar, 255).Value = SpecialRequests.Text;
cmd2.Parameters.Add("@BalanceOutstanding", SqlDbType.Int).Value = BalanceOutstanding.Text;
cmd2.Parameters.Add("@Comments", SqlDbType.VarChar, 50).Value = Comments.Text;
try
{
if (cmd2.Connection.State == ConnectionState.Closed)
{
cmd2.Connection.Open();
}
cmd2.ExecuteNonQuery();
}
catch (Exception)
{
}
finally
{
cmd2.Connection.Close();
}
}
当我们运行页面时,没有错误消息,但是数据没有出现在数据库中!
该存储过程将不接受参数值中的空值,因此您需要进行一些检查-也许可以。 您确实需要在Catch {}块中放入一些代码,以查看该过程是否返回错误。
我不知道您要在哪里阻止更新。 所出现的问题应在用户界面中解决。 如果任何条目为空,则不允许提交。 简单。
如果希望该过程避免执行更新,则应将所有参数设置为允许空值。 然后在允许更新之前检查是否有任何空值。 您可以抛出用户定义的错误或99(按设计)。 此方法还要求您仅在文本框不为空时设置参数值。
您的应用程序中有几个问题。
1.如注释中所述,使用int result = cmd.ExecuteNonQuery()
返回值(0或99)。 实际上这还不够。
2.检查您的表模式以查看关注字段是否allow null
。
3.在您的存储过程中使用事务。
...
AS
--DECLARE @error INT --no need
begin transaction
begin try
UPDATE BookingView
SET Balance_Outstanding = @BalanceOutstanding, Comments = @Comments
WHERE Booking_Ref = @BookingRef
UPDATE vBoat_Booking
SET BoatID = @BoatID, Lead_PassengerID = @LeadPassenger, Start_Date = @StartDate, Duration_In_hours = @Duration, Number_of_pets = @Pets,
Number_of_children = @Children, Number_of_passengers = @Passengers
WHERE Booking_Ref = @BookingRef
commit
end try
begin catch
DECLARE @ErrorMessage NVARCHAR(4000);
DECLARE @ErrorSeverity INT;
DECLARE @ErrorState INT;
SELECT
@ErrorMessage = ERROR_MESSAGE(),
@ErrorSeverity = ERROR_SEVERITY(),
@ErrorState = ERROR_STATE();
rollback
RAISERROR (@ErrorMessage, -- Message text.
@ErrorSeverity, -- Severity.
@ErrorState -- State.
)
end catch
--SET @error = @@error
--IF @error <> 0 RETURN 99
--ELSE RETURN 0
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.