Tuesday, October 25, 2011

ADO.NET interview questions: - What are the ways to implement optimistic locking in ADO.NET?

An interesting ADO.NET interview questions mostly asked by the interviewer during an interview. Following are the ways to implement optimistic locking using ADO.NET: -

  • When we call “Update” method of Data Adapter it handles locking internally. If the Dataset values are not matching with current data in Database, it raises concurrency exception error. We can easily trap this error using Try. Catch block and raise appropriate error message to the user.
     
  • Define a Date time stamp field in the table. When actually you are firing the UPDATE SQL statements, compare the current timestamp with one existing in the database. Below is a sample SQL which checks for timestamp before updating and any mismatch in timestamp it will not update the records. This I the best practice used by industries for locking.
   Update table1 set field1=@test where Last Timestamp=@Current Timestamp
  • Check for original values stored in SQL SERVER and actual changed values. In stored procedure check before updating that the old data is same as the current Example in the below shown SQL before updating field1 we check that is the old field1 value same. If not then some one else has updated and necessary action has to be taken.
Update table1 set field1=@test where field1 = @oldfield1value




Locking can be handled at ADO.NET side or at SQL SERVER side i.e. in stored procedures.

 Know more on UML’s object diagram by viewing the following video: -



For more on ADO.NET interview questions, so click and visit.

Regards,

Author’s more on ADO.NET interview questions.

No comments: