« Message d'erreur Buffer Received non valide à partir de client ? dans SQL Server journal lorsque vous utilisez des classes de fournisseur SQL Server.NET

Traductions disponibles Traductions disponibles
Numéro d'article: 827366 - Voir les produits auxquels s'applique cet article
Agrandir tout | Réduire tout

Symptômes

Lorsque vous utilisez une classe Microsoft .NET Framework SqlClient , vous recevez le message d'erreur suivant dans le journal des erreurs Microsoft SQL Server 2000 :
Erreur : 17805, gravité : 20, état: 3
Tampon non valide reçu à partir client.
Vous recevez des messages d'erreur correspondants suivants dans l'application cliente Microsoft .NET Framework :
System.Data.SqlClient.SqlException : une erreur grave est survenue dans la commande en cours. Les résultats, éventuel doivent être ignorées

Cause

Ce problème se produit si une des situations suivantes est remplie :
  • Vous utilisez une classe SqlClient dans une méthode Finalize ou dans un destructeur de C# .
  • Vous ne spécifiez pas une énumération SQLDbType explicite lorsque vous créez un objet SqlParameter . Lorsque vous ne spécifiez pas une énumération SQLDbType explicite, le fournisseur de données Microsoft .NET Framework pour SQL Server (SqlClient) essaie de sélectionner l'énumération SQLDbType appropriée en fonction des données qui sont transmises. SqlClient est infructueuse.
  • Vous déclarez une instance de la classe SqlClient soient statiques en C# ou partagé dans Visual Basic. L'instance accessibles simultanément depuis plusieurs threads dans l'application.

    note Dans l'environnement ASP.NET ou certains autres environnements, accès simultané est possible même si aucun threads supplémentaires ne sont créées explicitement dans le code d'application.
  • La taille du paramètre que vous spécifiez explicitement dans le code .NET Framework est dépasse la taille maximale que vous pouvez utiliser pour le type de données dans SQL Server.

    Par exemple, en fonction pour SQL Server documentation en ligne, nvarchar est une données de caractères Unicode longueur variable de n caractères. « n » doit être une valeur comprise entre 1 et 4 000. Si vous spécifiez une taille c'est-à-dire plus de 4000 pour un paramètre nvarchar , vous recevez le message d'erreur décrite dans la section « Symptômes ».
Le code suivant montre également comment ces erreurs peuvent se produire :
Stored Procedure
--------------------------

CREATE PROCEDURE spParameterBug @myText Text AS
            Insert Into ParameterBugTable (TextField) Values (@myText)

Code
-------
static void Main(string[] args)
{
       string dummyText=string.Empty;
       for (int n=0; n < /*80*/ 3277; n++)   // change this to 80 to receive the second error that is mentioned earlier in this article.
       {
             dummyText += "0123456789";
       }

        // TO DO: Change data source to match your SQL Server:

       SqlConnection con= new SqlConnection("data source=myserver;Initial Catalog=mydb;Integrated Security=SSPI;persist security info=True;packet size=16384");
       SqlCommand cmd = new SqlCommand("SpParameterBug", con);
      con.Open();
           // Causes error 17805:
      SqlParameter param2 =new SqlParameter("@myText", dummyText);
      cmd.CommandType = CommandType.StoredProcedure;
      cmd.Parameters.Add(param2);
      try
      {
          cmd.ExecuteNonQuery();
      } 
      catch (Exception err)
      {
         Console.WriteLine(err.ToString());
      }

      Console.ReadLine();

}

Résolution

Pour résoudre ces erreurs, assurez-vous d'effectuer les opérations suivantes :
  • N'utilisez pas une classe SqlClient dans une méthode Finalize ou dans un destructeur de C# .
  • Spécifier l'énumération SqlDbType pour l'objet SqlParameter afin qu'il n'y a aucun type déduit.
  • Spécifier une taille de paramètre qui est dans les limites du type de données.

Références

Pour plus d'informations sur la taille maximale des différents types de données, reportez-vous aux Web MSDN (Microsoft Developer Network) sites adresses suivantes :
http://msdn2.microsoft.com/en-us/library/aa276823(SQL.80).aspx
http://msdn2.microsoft.com/en-us/library/aa258271(SQL.80).aspx

Propriétés

Numéro d'article: 827366 - Dernière mise à jour: mercredi 18 avril 2007 - Version: 3.4
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft .NET Framework 1.0
Mots-clés : 
kbmt kbprb KB827366 KbMtfr
Traduction automatique
IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d?articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d?avoir accès, dans votre propre langue, à l?ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s?exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s?efforce aussi continuellement de faire évoluer son système de traduction automatique.
La version anglaise de cet article est la suivante: 827366
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Envoyer des commentaires

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com