Oprava: UNION dotaz vrátí vnitřní dotaz procesoru chybová zpráva 8623

Důležité: Tento článek byl přeložen pomocí software společnosti Microsoft na strojový překlad, ne profesionálním překladatelem. Společnost Microsoft nabízí jak články přeložené překladatelem, tak články přeložené pomocí software na strojový překlad, takže všechny články ve Znalostní databázi (Knowledge Base) jsou dostupné v češtině. Překlad pomocí software na strojový překlad ale není bohužel vždy dokonalý. Obsahuje chyby ve skloňování slov, skladbě vět, nebo gramatice, podobně jako když cizinci dělají chyby při mluvení v češtině. Společnost Microsoft není právně zodpovědná za nepřesnosti, chyby nebo škody vzniklé chybami v překladu, nebo při použití nepřesně přeložených instrukcí v článku zákazníkem. Společnost Microsoft aktualizuje software na strojový překlad, aby byl počet chyb omezen na minimum.

286255
Tento článek byl archivován. Je nabízen v takovém stavu, v jakém je, a nebude již nadále aktualizován.
CHYBA Č: 351259 (SHILOH_BUGS)
Příznaky
Příkaz dotazu se pravděpodobně nezdaří s chybovou zprávu 8623, pokud jsou splněny následující podmínky:
  • Dotaz používá klauzuli UNION.

  • Jeden z příkazů SELECT v dotazu UNION má klauzuli WHERE poddotazu prostřednictvím klauzule IN odkazuje.

  • Optimalizátor serveru SQL dotazu zvolí smyčky spojení k řešení dotazu.
Úplný text chybové zprávy je:
Server: Zpráva 8623 úroveň 16 stav 1 řádek 1 interní chyba Query procesor: procesor dotazu by není vyrobit plán dotazů. Další informace, obraťte se na poskytovatele primární podporu.
Řešení

Informace o aktualizaci Service Pack

Tento problém vyřešíte získat nejnovější aktualizaci service pack pro 2000 Microsoft SQL Server. Další informace naleznete následujícím článku znalostní databáze Microsoft Knowledge Base:
290211Jak získat nejnovější aktualizaci service pack pro SQL Server 2000

Informace o opravě hotfix

K dispozici je podporovaná oprava hotfix od společnosti Microsoft. Tato oprava hotfix je však určena pouze k opravě problému popsanému v tomto článku. Použijte tuto opravu hotfix pouze u systémů, kde dochází k tomuto konkrétnímu problému.

Pokud je oprava hotfix k dispozici ke stažení, v horní části tohoto článku je sekce "Hotfix stažení k dispozici". Není-li tato část uvedena, vyžádejte si tuto opravu hotfix od oddělení služeb zákazníkům a podpory společnosti Microsoft.

Poznámka: Pokud vyskytnout další problémy nebo jakékoli řešení potíží je vyžadován, pravděpodobně budete muset vytvořit zvláštní požadavek na službu. Výdaje na technickou podporu se týkají dalších otázek a problémů, které nelze vyřešit pomocí této opravy konkrétní opravy hotfix. Navštivte následující web společnosti Microsoft pro získání telefonního čísla na Zákaznické centrum, nebo pokud chcete vytvořit samostatnou žádost o podporu: Poznámka: Zobrazí formulář "Hotfix stažení k dispozici" jazyky, pro které je oprava hotfix k dispozici. Pokud váš jazyk není zobrazen, oprava hotfix není k dispozici pro daný jazyk.Anglická verze této opravy má následující atributy souborů nebo novější:
   Date         Time     Version    Size      File name      Platform   -------------------------------------------------------------------   01/13/2001   12:52a   8.00.240   7446589   Sqlservr.exe   Intel				
Poznámka: k vyřízení závislosti souborů nejnovější opravy hotfix nebo funkce, která obsahuje předchozí soubory může také obsahovat další soubory.
Jak potíže obejít
Tomuto chování můžete předejít pomocí následujících kroků:
  • Doplňte příkazu dotaz a spojení namísto poddotazu klauzule IN použít.

    Nebo

  • Vynutit sjednocení hash pomocí rada Optimalizátor OPTION. Příklad dotazu v části "Další informace" by změnit:

    SELECT P.EMP_NO, N.ADJ_SCON  FROM   BATCH_EMPEE P, EMPLOYEE E, NI_CONDITION N  WHERE  E.EMP_NO = P.EMP_NO AND         N.EMP_NO = E.EMP_NO AND         P.JOB_ID = 25 AND         N.PAYRUN_NO = 0  UNION  SELECT P.EMP_NO, ''  FROM   BATCH_EMPEE P, EMPLOYEE E  WHERE  E.EMP_NO = P.EMP_NO AND         P.JOB_ID = 25 AND         E.EMP_NO NOT IN             (SELECT EMP_NO FROM NI_CONDITION WHERE PAYRUN_NO = 0)  OPTION (HASH UNION)					
Prohlášení
Společnost Microsoft potvrzuje, že se to být problém v SQL Server 2000. Tento problém byl poprvé opraven v SQL Server 2000 Service Pack 1.
Další informace
Následující dotaz je příklad prohlášení, které mohou vést k chybová zpráva 8623:
SELECT P.EMP_NO, N.ADJ_SCON  FROM   BATCH_EMPEE P, EMPLOYEE E, NI_CONDITION N  WHERE  E.EMP_NO = P.EMP_NO AND         N.EMP_NO = E.EMP_NO AND         P.JOB_ID = 25 AND         N.PAYRUN_NO = 0  UNION  SELECT P.EMP_NO, ''  FROM   BATCH_EMPEE P, EMPLOYEE E  WHERE  E.EMP_NO = P.EMP_NO AND         P.JOB_ID = 25 AND         E.EMP_NO NOT IN             (SELECT EMP_NO FROM NI_CONDITION WHERE PAYRUN_NO = 0)				
Chybová zpráva 8623

Upozornění: Tento článek byl přeložen automaticky

Vlastnosti

ID článku: 286255 - Poslední kontrola: 02/28/2014 11:55:50 - Revize: 4.3

  • Microsoft SQL Server 2000 Developer Edition
  • Microsoft SQL Server 2000 Enterprise Edition
  • Microsoft SQL Server 2000 Personal Edition
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 2000 Workgroup Edition
  • kbnosurvey kbarchive kbmt kbautohotfix kbhotfixserver kbbug kbfix kbqfe KB286255 KbMtcs
Váš názor