CORRECTIF : sp_addmergearticle peut échouer avec l'erreur 20009 si l'article ajouté est filtré verticalement

Ancien nº de publication de cet article : F300172
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
N° DE BOGUE : 236010 (SHILOH_BUGS)
Symptômes
L'ajout d'un article à une publication à l'aide de sp_addmergearticle peut générer l'erreur suivante :
Msg 20009, Niveau 16, État 1, Serveur 'nom_serveur', Procédure sp_addmergearticle, Ligne 1202
L'article 'nom_article' ne peut pas être ajouté à la publication 'nom_publication'.
Ce problème peut survenir si les conditions suivantes sont réunies :
  • L'article a un filtre vertical.
  • L'article n'a pas encore de colonne uniqueidentifier avec la propriété ROWGUIDCOL activée.
  • L'article a une colonne identity où :
    1. La colonne identity est incluse dans la partition verticale. (Par exemple, si la colonne identity est une colonne de clé primaire, elle est automatiquement ajoutée au filtre.)
    2. La colonne identity est configurée de façon à gérer les plages d'identité dans tous les réplicas (@auto_identity_range='true').
    3. La propriété Not for Replication n'est pas définie pour la colonne identity.
Résolution
Pour résoudre ce problème, procurez-vous le dernier Service Pack de SQL Server 2000. Pour plus d'informations, consultez l'article suivant dans la Base de connaissances Microsoft :
290211 INF : Procédures pour obtenir le dernier Service Pack de SQL Server 2000
Contournement
Pour contourner ce problème, vous pouvez entreprendre l'une des actions suivantes avant l'exécution de sp_addmergearticle :
  • Définissez manuellement la propriété Not For Replication sur la colonne identity.- ou -

  • - ou -Si la table comporte déjà une colonne uniqueidentifier, activez la propriété ROWGUIDCOL pour cette colonne. S'il n'y a pas de colonne uniqueidentifier, ajoutez une nouvelle colonne appelée " rowguid " avec le type de données uniqueidentifier et la propriété ROWGUIDCOL définie.
Statut
Microsoft a confirmé l'existence de ce problème dans SQL Server 2000. Ce problème a été corrigé dans le Service Pack 1 de SQL Server 2000.
Propriétés

ID d'article : 300172 - Dernière mise à jour : 01/16/2015 22:50:36 - Révision : 3.1

Microsoft SQL Server 2000 Standard

  • kbnosurvey kbarchive kbbug kbfix kbsqlserv2000bug kbsqlserv2000sp1fix KB300172
Commentaires
ERROR: at System.Diagnostics.Process.Kill() at Microsoft.Support.SEOInfrastructureService.PhantomJS.PhantomJSRunner.WaitForExit(Process process, Int32 waitTime, StringBuilder dataBuilder, Boolean isTotalProcessTimeout)