繁体   English   中英

使用存储过程使用文本框中的值更新SQL Server数据库

[英]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
  1. 在C#中,使用catch部分查看发生了什么。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM