473,396 Members | 1,982 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,396 software developers and data experts.

sqlstransaction problem

Hi all,
I have placeOrder function which look like the following:
Protected Function PlaceOrder() As Boolean
Dim myConnection As SqlConnection = New
SqlConnection(ConfigurationSettings.AppSettings("C onnectionString"))
myConnection.Open()
Dim myCommand As SqlCommand = myConnection.CreateCommand()
Dim myTrans As SqlTransaction
myTrans = myConnection.BeginTransaction
'Must assign both transaction object and connection to command
object for a pending local trxn
myCommand.Connection = myConnection
myCommand.Transaction = myTrans
If Request.Cookies("Subway_StoreID").Value <> "" And
Session("FirstName") <> "" And Session("LastName") <> "" And Session("SSN")
<> "" Then
Try

Dim myOrder As Order = New Order

myOrder.AddEmployee(StoreID, Session("FirstName"),
Session("MI"), Session("LastName"), Session("Sex"), _
Session("SSN"), Session("Address"), Session("City"),
Session("State"), Session("Zip"), _
Session("DayPhone"), Session("EvePhone"),
Session("depenFlag"))
If Session("depenFlag") And Not Session("ctrlarr") Is
Nothing Then
Dim ctrlarr(5) As PeopleInfo
Dim i As Integer
ctrlarr = Session("ctrlarr")
For i = 0 To 5
If ctrlarr(i).FirstName <> "" And
ctrlarr(i).LastName <> "" And ctrlarr(i).SSN <> "" Then
'add employee's dependent
myOrder.AddDependent(ctrlarr(i).FirstName,
ctrlarr(i).MI, ctrlarr(i).LastName, Session("SSN"), "N", ctrlarr(i).SSN)
End If
Next
End If
myOrder.PlaceEmployeeOrder(PeriodCovered, Session("Plan"),
OrderTotal, PaymentReceived, Session("depenFlag"), PaymentMethod, _
Session("SSN"), MonthlyPayment)
myTrans.Commit()

Catch e As Exception
Try
myTrans.Rollback()

Catch ex As Exception
If Not myTrans.Connection Is Nothing Then
Label2.Text &= "An exception of type " &
ex.GetType().ToString() & _
" was encountered while attempting to roll back
the transaction. "

End If
End Try
Label2.Text &= "An exception of type " &
e.GetType().ToString() & _
" was encountered while inserting the data. "
Finally
myConnection.Close()

End Try
End If

End Function
After I call this function, I found that even I have problem with data
insertion for the dependents, and the statement myTrans.Rollback() is
executed and somehow the employee data is in the database already, it seems
not rolling back. I think is because in the method
myOrder.AddEmployee, I called a store procedure which seperately opens
another connection, that's why. Can you tell me in this case, do I have to
directly write insert statement in the application layer instead of using
data access layer store procedure?
here is the data access layer code:
Public Function AddEmployee(ByVal StoreID As String, ByVal FName As String,
ByVal MI As Char, ByVal LName As String, _
ByVal sex As String, ByVal ssn As String, ByVal Address As String,
ByVal City As String, ByVal State As String, ByVal Zip As String, _
ByVal Dayphone As String, ByVal Evephone As String, ByVal DFlag As
Boolean)
Dim myConnection As SqlConnection = New
SqlConnection(ConfigurationSettings.AppSettings("C onnectionString"))
Dim myCommand As SqlCommand = New SqlCommand("Add_employee",
myConnection)
myCommand.CommandType = CommandType.StoredProcedure

Dim pStoreID As SqlParameter = New SqlParameter("@storeID",
SqlDbType.VarChar, 50)
pStoreID.Value = StoreID
myCommand.Parameters.Add(pStoreID)

Dim pFName As SqlParameter = New SqlParameter("@FName",
SqlDbType.VarChar, 50)
pFName.Value = FName
myCommand.Parameters.Add(pFName)
...

myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
End Function
--
Betty
Feb 6 '06 #1
1 971
Hi Betty,

Welcome.

I think the problem here is just as you mentioned, the insert store
procedure call is executing on a different connection from other sql
statements in your main function. And ADO.NET SqlTransaction is connection
based, so all the SqlCommands which want to participate in the same
Transaction need to assign their Transaction property to a certain
SqlTransaction instance of a single SqlConnection.

Regards,

Steven Cheng
Microsoft Online Support

Get Secure! www.microsoft.com/security
(This posting is provided "AS IS", with no warranties, and confers no
rights.)
Feb 7 '06 #2

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

0
by: Bruce Davis | last post by:
I'm having a problem on windows (both 2000 and XP) with a multi-threaded tkinter gui application. The problem appears to be a deadlock condition when a child thread pops up a Pmw dialog window in...
11
by: Kostatus | last post by:
I have a virtual function in a base class, which is then overwritten by a function of the same name in a publically derived class. When I call the function using a pointer to the derived class...
0
by: Refky Wahib | last post by:
Hi I need Technical Support I finished a Great project using .Net and SQL Server and .Net Mobile Control My Business case is to implement this Program to accept about 1 Million concurrent...
9
by: Sudesh Sawant | last post by:
Hello, We have an application which communicates using remoting. There is a server which is a Windows Service. The server exposes an object which is a singleton. The client is a Web Application...
117
by: Peter Olcott | last post by:
www.halting-problem.com
28
by: Jon Davis | last post by:
If I have a class with a virtual method, and a child class that overrides the virtual method, and then I create an instance of the child class AS A base class... BaseClass bc = new ChildClass();...
6
by: Ammar | last post by:
Dear All, I'm facing a small problem. I have a portal web site, that contains articles, for each article, the end user can send a comment about the article. The problem is: I the comment length...
16
by: Dany | last post by:
Our web service was working fine until we installed .net Framework 1.1 service pack 1. Uninstalling SP1 is not an option because our largest customer says service packs marked as "critical" by...
2
by: Mike Collins | last post by:
I cannot get the correct drop down list value from a drop down I have on my web form. I get the initial value that was loaded in the list. It was asked by someone else what the autopostback was...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.