Was this page helpful?
Your feedback about this content is important. Let us know what you think.
Additional feedback?
1500 characters remaining
SqlPipe Class

SqlPipe Class

Allows managed stored procedures running in-process on a SQL Server database to return results back to the caller. This class cannot be inherited.


Namespace:  Microsoft.SqlServer.Server
Assembly:  System.Data (in System.Data.dll)

public sealed class SqlPipe

The SqlPipe type exposes the following members.

Public propertyIsSendingResultsGets a value that indicates whether the SqlPipe is in the mode of sending single result sets back to the client. This property is read-only.

Public methodEquals(Object)Determines whether the specified object is equal to the current object. (Inherited from Object.)
Public methodExecuteAndSendExecutes the command passed as a parameter and sends the results to the client.
Public methodGetHashCodeServes as the default hash function. (Inherited from Object.)
Public methodGetTypeGets the Type of the current instance. (Inherited from Object.)
Public methodSend(SqlDataReader)Sends a multirow result set directly to the client or current output consumer.
Public methodSend(SqlDataRecord)Sends a single-row result set directly to the client or current output consumer.
Public methodSend(String)Sends a string message directly to the client or current output consumer.
Public methodSendResultsEndMarks the end of a result set, and returns the SqlPipe instance back to the initial state.
Public methodSendResultsRowSends a single row of data back to the client.
Public methodSendResultsStartMarks the beginning of a result set to be sent back to the client, and uses the record parameter to construct the metadata that describes the result set.
Public methodToStringReturns a string that represents the current object. (Inherited from Object.)

An instance of this class is made available to managed stored procedures through the Pipe property of the SqlContext class.

The following example uses SqlConnection and SqlCommand to select rows from a data source in a stored procedure. The example then uses a SqlPipe to execute the command and send the results back to the client.

	public static void StoredProcExecuteCommand(int rating)
		// Connect through the context connection. 
		using (SqlConnection connection = new SqlConnection("context connection=true"))

			SqlCommand command = new SqlCommand(
				"SELECT VendorID, AccountNumber, Name FROM Purchasing.Vendor " +
				"WHERE CreditRating <= @rating", connection);
			command.Parameters.AddWithValue("@rating", rating);

			// Execute the command and send the results directly to the client.

.NET Framework

Supported in: 4.6, 4.5, 4, 3.5, 3.0, 2.0

.NET Framework Client Profile

Supported in: 4, 3.5 SP1

Any public static (Shared in Visual Basic) members of this type are thread safe. Any instance members are not guaranteed to be thread safe.
© 2015 Microsoft