Partager via


Objet SqlDataRecord

L'objet SqlDataRecord représente une ligne unique de données avec ses métadonnées connexes.

Les procédures stockées managées peuvent envoyer au client des jeux de résultats clients qui ne proviennent pas d'un SqlDataReader. La classe SqlDataRecord, avec les méthodes SendResultsStart, SendResultsRow et SendResultsEnd de l'objet SqlPipe, permet aux procédures stockées d'envoyer des jeux de résultats personnalisés au client.

Pour plus d'informations, consultez la documentation de référence sur la classe Microsoft.SqlServer.Server.SqlDataRecord dans la documentation du Kit de développement logiciel (SDK) .NET Framework.

Exemple

L'exemple suivant crée un nouvel enregistrement d'employé et le retourne à l'appelant.

C#

[Microsoft.SqlServer.Server.SqlProcedure]
public static void CreateNewRecordProc()
{
    // Variables.       
    SqlDataRecord record;

    // Create a new record with the column metadata.  The constructor 
    // is able to accept a variable number of parameters.
    record = new SqlDataRecord(new SqlMetaData("EmployeeID", SqlDbType.Int),
                               new SqlMetaData("Surname", SqlDbType.NVarChar, 20),
                               new SqlMetaData("GivenName", SqlDbType.NVarChar, 20),
                               new SqlMetaData("StartDate", SqlDbType.DateTime) );

    // Set the record fields.
    record.SetInt32(0, 0042);
    record.SetString(1, "Funk");
    record.SetString(2, "Don");
    record.SetDateTime(3, new DateTime(2005, 7, 17));

    // Send the record to the calling program.
    SqlContext.Pipe.Send(record);

}

Visual Basic

<Microsoft.SqlServer.Server.SqlProcedure()> _
Public Shared Sub  CreateNewRecordVBProc ()
    ' Variables.
    Dim record As SqlDataRecord

    ' Create a new record with the column metadata. The constructor is 
    ' able to accept a variable number of parameters

    record = New SqlDataRecord(New SqlMetaData("EmployeeID", SqlDbType.Int), _
                           New SqlMetaData("Surname", SqlDbType.NVarChar, 20), _
                           New SqlMetaData("GivenName", SqlDbType.NVarChar, 20), _
                           New SqlMetaData("StartDate", SqlDbType.DateTime))

    ' Set the record fields.
    record.SetInt32(0, 42)
    record.SetString(1, "Funk")
    record.SetString(2, "Don")
    record.SetDateTime(3, New DateTime(2005, 7, 17))

    ' Send the record to the calling program.
    SqlContext.Pipe.Send(record)

End Sub

Historique des modifications

Mise à jour du contenu

Mise à jour du lien vers l'exemple.