Les performances sont ralenties lorsque vous exécutez une requête dans SQL Server 2005 qui met à jour une table sur un serveur lié et puis joint la table à une table sur le serveur local
Vous avez une requête qui met à jour une table sur un serveur lié et puis joint la table à une table sur le serveur local.
Le serveur local exécute Microsoft SQL Server 2005.
Sur le serveur local, vous exécutez la requête dans SQL Server 2005.
Dans ce scénario, performances est lent par rapport aux performances de la même requête dans Microsoft SQL Server 2000. Par exemple, lorsque vous exécutez la requête dans SQL Server 2000, la requête est inférieur à 1 seconde à la fin. Toutefois, lorsque vous exécutez la requête dans SQL Server 2005, la requête est environ 24 secondes à la fin.
La requête effectue une opération analyse à distance de la table sur le serveur lié. Lorsque vous exécutez la requête dans SQL Server 2005, l'opération d'analyse à distance récupère toutes les lignes de la table. Si la table contient autant de lignes, l'opération d'analyse à distance prend longtemps à la fin.
Toutefois, lorsque vous exécutez la requête dans SQL Server 2000, l'opération de requête à distance envoie la requête à exécuter sur le serveur lié. Par conséquent, même si la table contient plusieurs lignes, l'opération d'analyse à distance est terminée en peu de temps.
Pour contourner ce problème, ajouter une contrainte UNIQUE ou une contrainte de clé primaire de la table sur le serveur local. Ajouter la contrainte à la colonne que vous utilisez pour l'opération JOIN.
Par exemple, vous mettre à jour l'instruction DECLARE qui est mentionnée dans l'étape 4 les autres informations section à la suivante :
note Les étapes suivantes supposent que vous disposez de deux serveurs qui exécutent SQL Server 2005. Un nom d'instance est ServerA\SQL2005. L'autre nom d'instance est ServerB\SQL2005.
Sur l'instance de serveur A de SQL Server 2005, exécutez les instructions suivantes pour créer une base de données dans SQL Server Management Studio :
USE MASTER
GO
IF EXISTS (SELECT * FROM sysdatabases where name = 'LinktestTarget')
DROP DATABASE LinktestTarget
GO
CREATE DATABASE LinktestTarget
GO
ALTER DATABASE LinktestTarget MODIFY FILE
(NAME = 'LinktestTarget', SIZE = 200MB)
GO
ALTER DATABASE LinktestTarget MODIFY FILE
(NAME = 'LinktestTarget_log', SIZE = 100MB)
GO
Sur l'instance le serveur B de SQL Server 2005, exécutez les instructions suivantes pour créer un serveur lié dans Management Studio :
Sur l'instance de serveur A de SQL Server 2005, exécutez l'instruction suivante pour créer une table, puis puis remplissez la table avec les 50 000 lignes de données :
USE LinktestTarget
GO
CREATE TABLE [T1] (
[c1] [int] NOT NULL,
[c2] [int] NOT NULL,
[c3] char (4000) NOT NULL,
CONSTRAINT [PK_t1] PRIMARY KEY CLUSTERED ([c1])
WITH FILLFACTOR = 80 ON [PRIMARY]
) ON [PRIMARY]
GO
SET NOCOUNT ON
GO
DECLARE @counter int
SET @counter = 1
WHILE @counter < 50000
BEGIN
INSERT INTO T1 (c1, c2, c3) VALUES (@counter, @counter,'')
SET @counter = @counter + 1
END
GO
UPDATE STATISTICS T1 (PK_t1) WITH FULLSCAN
Sur l'instance le serveur B de SQL Server 2005, exécutez les instructions suivantes. Notez que les performances sont lente.
DECLARE @t2 table (c1 int, c2 int)
INSERT INTO @t2 (c1, c2) VALUES (399990, 399990)
UPDATE A
SET A.c2 = B.c2
FROM LS.LinktestTarget.dbo.T1 AS A
JOIN @t2 as B on B.c1 = A.c1
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: 942982
(http://support.microsoft.com/kb/942982/en-us/
)
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.
Merci ! Vos commentaires sont très utiles pour l'amélioration de notre contenu d'aide et de support. Si vous avez besoin d'aide complémentaire, veuillez consulter la page d'accueil d'aide et support.