CORRECTIF : SQL Server 2005 traite une colonne d'identité dans une vue comme une colonne int ordinaire lorsque le niveau de compatibilité de la base de données est à 80

Traductions disponibles Traductions disponibles
Numéro d'article: 920974 - Voir les produits auxquels s'applique cet article
Bogue: #910 (correctifs SQL)
Microsoft distribue les correctifs Microsoft SQL Server 2005 le biais comme un fichier téléchargeable. Les correctifs étant cumulatifs, chaque nouvelle version contient tous les correctifs et tous les correctifs de sécurité qui étaient fournis avec la précédente SQL Server 2005 version du correctif.
Agrandir tout | Réduire tout

Résumé

Cet article décrit suivants concernant cette version de correctif logiciel :
  • Les problèmes qui sont résolus par ce package de correctifs
  • Les conditions requises pour appliquer le package de correctifs
  • Si vous devez redémarrage de l'ordinateur après avoir appliqué le package de correctifs
  • Savoir si le package de correctifs est remplacé par un autre package de correctif
  • Informations si vous devez apporter les modifications du Registre après avoir appliqué le package de correctifs
  • Les fichiers qui sont contenus dans le package de correctifs

Symptômes

Envisagez le scénario suivant. Vous avez une base de données dans SQL Server 2005. Vous définir le niveau de compatibilité de la base de données à 80. Vous avez une vue existante ou vous créez un affichage dans la base de données. L'affichage remplit les conditions suivantes :
  • L'affichage est créé sur deux tables dans la base de données.
  • L'affichage inclut une colonne identité d'une des tables.
Dans ce scénario, SQL Server 2005 ne considère que la colonne d'identité dans l'affichage comme une colonne ordinaire int . Toutefois, si vous avez la même vue dans Microsoft SQL Server 2000, SQL Server 2000 traite la colonne en tant que colonne identité .

Pour vérifier ce problème dans SQL Server 2005, vous pouvez interroger la colonne is_identity dans l'affichage de catalogue sys.columns par rapport à la colonne d'identité dans l'affichage. Notez que SQL Server 2005 renvoie la valeur 0 pour la colonne des identités dans l'affichage.

Le niveau de compatibilité de la base de données dans SQL Server 2005 peut également être défini à 80 dans les cas suivants :
  • Mise à niveau une base de données SQL Server 2000 existante vers SQL Server 2005. La base de données SQL Server 2000 disposent du niveau compatibilité de 80 dans SQL Server 2005.
  • Vous détachez une base de données à partir de SQL Server 2000, puis attacher la base de données à SQL Server 2005. La base de données disposent du niveau compatibilité de 80 dans SQL Server 2005.

Cause

Ce problème se produit car SQL Server 2005 traite la colonne des identités de l'affichage comme une colonne int . Ce problème se produit même après avoir défini le niveau de compatibilité de la base de données à 80 (SQL Server 2000).

Résolution

Un correctif est disponible auprès de Microsoft. Toutefois, ce correctif est conçu pour corriger le problème décrit dans cet article. Appliquer ce correctif uniquement aux systèmes rencontrant ce problème spécifique. Ce correctif peut subir des tests supplémentaires. Par conséquent, si vous n'êtes pas gravement touché par ce problème, nous vous recommandons d'attendre la prochaine mise à jour logicielles qui contiendra ce correctif.

Si le correctif est disponible pour le téléchargement, il est une section « téléchargement correctif disponible » en haut de cet article de la base de connaissances. Si cette section n'apparaît pas, contactez le service clientèle Microsoft et de support pour obtenir le correctif.

note Si des problèmes supplémentaires se produisent ou si n'importe quel dépannage est nécessaire, vous devrez peut-être créer une demande de service distincte. Les coûts habituels du support technique s'appliqueront aux autres questions et problèmes non traités par ce correctif spécifique. Pour une liste complète des Microsoft client service et support numéros de téléphone ou pour créer une demande de service distincte, reportez-vous au site de Web Microsoft suivant :
http://support.microsoft.com/contactus/?ws=support
note L'écran de « téléchargement correctif disponible » affiche les langues pour lesquelles le correctif est disponible. Si vous ne voyez pas la langue, il est car un correctif logiciel n'est pas disponible pour cette langue.

Conditions préalables

Vous Microsoft SQL Server 2005 Service Pack 1 devez être (SP1) pour appliquer ce correctif.

Pour plus d'informations sur la façon d'obtenir SQL Server 2005 Service Pack 1, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
913089 Comment obtenir le dernier pack service pour SQL Server 2005

Redémarrez les informations

Vous devez redémarrer l'ordinateur après avoir appliqué ce correctif.

Informations de Registre

Vous n'avez pas modifier le Registre.

Informations sur le fichier de correctif

Ce correctif contient uniquement les fichiers nécessaires à la résolution des problèmes décrits dans cet article. Ce correctif peut ne pas contenir de tous les fichiers nécessaires à la mise à jour complètement un produit vers la dernière version.

La version anglaise de ce correctif dispose les attributs de fichier (ou attributs de fichier version ultérieure) répertoriés dans le tableau suivant. Les dates et heures de ces fichiers sont exprimées en temps universel coordonné (UTC). Lorsque vous affichez les informations de fichier, il est convertie en heure locale. Pour connaître le décalage entre l'heure UTC et l'heure locale, utilisez l'onglet Fuseau horaire dans l'élément Date et heure du Panneau de configuration.
SQL Server 2005, 32 bits x 86 versions
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Logread.exe2005.90.2167.0398,11220-Juin 200615:35x 86
Microsoft.SqlServer.SqlEnum.dll9.0.2167.0908,06420-Juin 200615:37x 86
Ms.SS.mgdsqldumper.dll2005.90.2167.075,55220-Juin 200615:29x 86
Msgprox.dll2005.90.2167.0197,92020-Juin 200615:32x 86
Replprov.dll2005.90.2167.0547,61620-Juin 200615:35x 86
Replrec.dll2005.90.2167.0782,11220-Juin 200615:36x 86
Sbmsmdlocal.dll9.0.2167.015,662,36820-Juin 200615:32x 86
Sqlaccess.dll2005.90.2167.0347,93620-Juin 200615:34x 86
Sqlservr.exe2005.90.2167.028,950,36020-Juin 200615:32x 86
SQL Server 2005, version 64 bits
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Logread.exe2005.90.2167.0522,52820-Juin 200615:29x 64
Microsoft.SqlServer.SqlEnum.dll9.0.2167.0875,29620-Juin 200615:31x 86
Ms.SS.mgdsqldumper.dll2005.90.2167.091,42420-Juin 200615:30x 64
Msgprox.dll2005.90.2167.0259,36020-Juin 200615:28x 64
Replprov.dll2005.90.2167.0745,24820-Juin 200615:30x 64
Replrec.dll2005.90.2167.01,008,41620-Juin 200615:31x 64
Sbmsmdlocal.dll9.0.2167.015,662,36820-Juin 200615:32x 86
Sqlaccess.dll2005.90.2167.0355,10420-Juin 200615:29x 86
Sqlservr.exe2005.90.2167.039,262,49620-Juin 200615:32x 64
SQL Server 2005, version d'architecture Itanium
Réduire ce tableauAgrandir ce tableau
Nom de fichierVersion du fichierTaille du fichierDateHeurePlate-forme
Logread.exe2005.90.2167.01,094,94420-Juin 200606:39IA-64
Microsoft.SqlServer.SqlEnum.dll9.0.2167.0875,29620-Juin 200606:39x 86
Ms.SS.mgdsqldumper.dll2005.90.2167.0163,10420-Juin 200606:41IA-64
Msgprox.dll2005.90.2167.0542,49620-Juin 200606:38IA-64
Replprov.dll2005.90.2167.01,617,18420-Juin 200606:39IA-64
Replrec.dll2005.90.2167.02,141,47220-Juin 200606:39IA-64
Sbmsmdlocal.dll9.0.2167.048,738,59220-Juin 200606:39IA-64
Sqlaccess.dll2005.90.2167.0349,47220-Juin 200606:38x 86
Sqlservr.exe2005.90.2167.072,183,07220-Juin 200606:39IA-64

Statut

Microsoft a confirmé que c'est un problème dans les produits Microsoft répertoriés dans la section « S'applique à ».

Plus d'informations

Pour modifier le comportement de SQL Server 2005 après avoir appliqué ce correctif, vous effectuez une des actions suivantes :
  • Si l'affichage dans la base de données n'est pas créée en utilisant l'option WITH SCHEMABINDING , vous devez exécutez la procédure sp_refreshview stockées dans l'affichage.
  • Si l'affichage dans la base de données est créée en utilisant l'option WITH SCHEMABINDING , vous devez quitter (abandonner l'affichage tout d'abord). Ensuite, recréez l'affichage.
Après cela, SQL Server 2005 traite la colonne d'identité dans l'affichage la même comme SQL Server 2000 pour les affichages existants.

Pour les affichages nouvellement créés après avoir appliqué le correctif, SQL Server 2005 traite la colonne d'identité dans l'affichage la même comme SQL Server 2000. En outre, si vous joignez une base de données SQL Server 2000, les vues dans la base de données liée sont également la même traités comme SQL Server 2000.

Pour plus d'informations sur la procédure sp_refreshview stockés, reportez-vous au site de Web MSDN (Microsoft Developer Network) suivant :
http://msdn2.microsoft.com/en-us/library/ms187821.aspx
Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
824684 Description de la terminologie standard utilisée pour décrire les mises à jour logicielles Microsoft

Propriétés

Numéro d'article: 920974 - Dernière mise à jour: mardi 20 novembre 2007 - Version: 1.7
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL Server 2005 Enterprise Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition
Mots-clés : 
kbmt kbautohotfix kbtshoot kbsql2005engine kbhotfixserver kbqfe kbpubtypekc KB920974 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: 920974
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