DetailPage-MSS-KB

Base de connaissances

Numéro d'article: 933697 - Dernière mise à jour: mardi 13 mars 2007 - Version: 1.2

 

Sommaire

Symptômes

Lorsque vous exécutez une requête SELECT dans SQL Server 2005 Mobile Edition et Microsoft SQL Server 2005 Compact Edition, la requête renvoie inattendue un nombre de lignes incorrect. Ce problème se produit si les conditions suivantes sont remplies :
  • La requête SELECT contient une jointure interne.
  • Une des deux tables qui sont jointes a un index dans la colonne jointe. L'autre table n'a aucun index sur une des ses colonnes.
Par exemple, vous exécutez la requête suivante dans SQL Server 2005 Mobile Edition :
select * from T1, T2 where T1.Col = T2.Col1 order by T1.Col
Remarque dans cet exemple, table t1 a un index sur la colonne T2 table colonnes... ne comporte pas un index sur la colonne Col1.

Cause

Ce problème se produit car l'optimiseur de requête ne pas annuler le plan précédent complètement. L'optimiseur de requête considère plusieurs plans de requête avant que l'optimiseur de requête décide du meilleur plan pour exécuter une requête. Dans certains cas, l'optimiseur de requête trouverez un plan qui utilise un index pour évaluer la condition. Toutefois, l'optimiseur de requête peut trouver ultérieurement un meilleur plan. Dans ce cas, l'optimiseur de requête ignore le plan précédent à utiliser le meilleur plan.

Résolution

Pour résoudre ce problème, appliquez l'une des méthodes suivantes :
  • Créer un index dans la colonne jointe dans la seconde table.
  • Supprimer l'index de la colonne jointe pour la première table.
note Dans l'exemple dans la section « Symptômes », la colonne jointe de la seconde table est T2.Col1. La colonne jointe de la première table est T1.Col.

Statut

Microsoft a confirmé qu'il s'agit un bogue dans les produits Microsoft répertoriés dans la section « S'applique à ».

Plus d'informations

Procédure pour reproduire le problème

  1. Exécutez les instructions suivantes par rapport à une base de données dans SQL Server 2005 Mobile Edition :
    CREATE TABLE T1 (COL INT);
    GO;
    CREATE INDEX T1_IDX ON T1 (COL);
    GO;
    INSERT INTO T1 VALUES (1);
    INSERT INTO T1 VALUES (2);
    INSERT INTO T1 VALUES (3);
    GO;
    CREATE TABLE T2 (COL1 INT, COL2 INT);
    GO;
    INSERT INTO T2 VALUES (1,1);
    INSERT INTO T2 VALUES (2,2);
    INSERT INTO T2 VALUES (3,3);
    GO;
  2. Exécutez l'instruction suivante :
    select * from T1, T2 where T1.Col = T2.Col1 order by T1.Col
    vous rencontrez le problème décrit dans la section « Symptômes ».

Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft SQL Server 2005 Mobile Edition
  • Microsoft SQL Server 2005 Compact Edition
Mots-clés : 
kbmt kbtshoot kbexpertiseadvanced kbbug KB933697 KbMtfr
Traduction automatiqueTraduction 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: 933697  (http://support.microsoft.com/kb/933697/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.
Partager
Options de support supplémentaire
Forums du support Microsoft Community
Nous contacter directement
Trouver un partenaire Microsoft Certified Partner
Microsoft Store