Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

SqlDataAdapter use results in SQL Server processes 'AWAITING COMMAND'?

Status
Not open for further replies.

MikeL04

Programmer
Aug 8, 2002
32
CA
I originally posted this in the ASP.Net forum but have not recieved a reponse and the problem is getting worse with SQL Server 2000 maintaining many proceses for what seems to be no reason. The SQL stored proc is listed at the bottom of this post.

I have a web app in ASP.Net that uses a Data Access Logic Component that has the following method to return a DataRow to the calling business logic. This may be called 10+ times on rendering the aspx page to the client depending on the number of pannels with dynamic help on a page. I have ran into the problem of getting SQL connection errors recently and discovered that each time this method is called it creates a SQL process in the sleeping 'AWAITING COMMAND' state referencing the associated stored proceedure from this method. After using the web app for 30 minutes the number of processes like this can top 200 resulting in my connection issues.

My understanding was that the SqlDataAdapter managed these types of connections and disposed of them once the command was complete which is not happening for me here. Especially since the purpose of the SqlDataAdapter and DataSet is for diconnected data access. I have tried manually disposing of everything from th econnection, command, and data adapter objects when finished with them but the result is the same.

Is this accumulation of SQL Server processes normal when using the SqlDataAdapter or am I doing something wrong.. or forgetting to do something?


Any help or insight appreciated.

TIA,

Mike

Code:
Public Function GetHelpItem(ByVal WebUserHelpLabel As String, ByVal LanguageID As Integer) As DataRow
    Dim cmd As New SqlCommand("WebUserHelp_GetItemByLabelID", conn)

    cmd.CommandType = CommandType.StoredProcedure
    cmd.Parameters.Add(New SqlParameter("@WebUserHelpLabel", SqlDbType.VarChar))
    cmd.Parameters("@WebUserHelpLabel").Value = WebUserHelpLabel
    cmd.Parameters.Add(New SqlParameter("@LanguageID", SqlDbType.Int))
    cmd.Parameters("@LanguageID").Value = LanguageID

    Dim da As New SqlDataAdapter(cmd)
    Dim ds As New DataSet
    Dim dr As DataRow

    da.Fill(ds, "HelpItem")
    
    If ds.Tables(0).Rows.Count = 0 Then
      Dim rowVals(1) As Object
      rowVals(0) = ""
      rowVals(1) = ""

      ds.Tables(0).Rows.Add(rowVals)
    End If

    dr = ds.Tables(0).Rows(0)

    Return dr
  End Function

The Stored proceedure "WebUserHelp_GetItemByLabelID" is as follows:

Code:
CREATE    PROCEDURE dbo.WebUserHelp_GetItemByLabelID
	@WebUserHelpLabel varchar(50)
	,@LanguageID      int
AS

SET NOCOUNT ON

SELECT
	m.HelpTextBackEnd
	,m.HelpTextFrontEnd
FROM
	main_WebUserHelp 		   h
	JOIN main_WebUserHelp_Multilingual m ON h.WebUserHelpID = m.WebUserHelpID
WHERE
	h.WebUserHelpLabel = @WebUserHelpLabel
	AND m.LanguageID = @LanguageID
 
It's better to know that someone else out ther has the same problem. Im using a DataAdapter just as you are, on a very data intensive site. I dispose of the adapter immediately after filling the table and close the connection after each use. The connections are still not being killed on the server and take a long time to timeout. On days of heavy traffic we need to reboot MSSQL server or the web server about 5 times to destroy the connections because there are just too many open connections. Any help here would be greatly appreciated.
 
Hello mukluk,

I have since resolved the issue and actually I was wrong when assuming it was due to the DataAdapter.

In my case I had a class (say MyPage) that inherits from System.Web.UI.Page that is used for all aspx pages that provides the user and role control and application config etc. In this class a cusom translator class is instantiated opening a db connection that is used to perform any translations on a page. The connection is closed when MyPage is disposed. Because I implemented the WebUserHelp module as rendered server control, it did not inherit from our MyPage and so it needed its own translator object which is instatiated on the creation of the control, thus opening the connection. Because the .dispose() was not called as is it in MyPage the connection was getting left open. Within my server control I now close the connection when finished with the localized translator object and the problem is solved.

I was missled originally as to where the connection was being leaked, it is not a result of the use a DataAdapter like I originally thought.


Hope this helps.

Mike
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top