Symptomy

Typ danych kolumny w tabeli bazy danych można zmienić z ntext na nvarchar (max) na serwerze, na którym działa program Microsoft SQL Server 2012, 2014 lub 2016. Po zaktualizowaniu tabeli przez dodanie więcej niż 4 000 rekordów polecenie DBCC CHECKDB może raportować błędy podobne do następujących:

Msg 8961, poziom 16, stan 1, LineNumber Błąd tabeli: objectid, indexID, PartitionID, allocUnitID (dane typu LOB). Węzeł dane spoza wiersza na stronie (pageid), gniazdo 0, textID nie pasuje do odwołania od strony (pageid), gniazdo 0. Msg 8961, poziom 16, stan 1, LineNumber Błąd tabeli: objectid, indexID, PartitionID, allocUnitID (dane typu LOB). Węzeł dane spoza wiersza na stronie (pageid), gniazdo 0, textID nie pasuje do odwołania od strony (pageid), gniazdo 0. Msg 8929, Level 16, State 1, LineNumberobjectid, indexID, PartitionID, allocUnitID (dane typu w wierszu): Błędy występujące w danych poza wierszami o identyfikatorze należącym do rekordu o identyfikatorze RID = (RID) Wyniki polecenia DBCC dla "TableName". W przypadku obiektu "TableName" istnieją 1 wiersze na 1 stronach. CHECKTABLE znaleziono 0 błędów przydziałów i 3 błędy spójności w tabeli "TableName" (objectid). repair_allow_data_loss jest minimalnym poziomem naprawy błędów znalezionych przez polecenie DBCC CHECKTABLE (DatabaseName. TableName). Ukończono wykonywanie polecenia DBCC. Jeśli zostanie wydrukowany komunikat o błędzie, skontaktuj się z administratorem systemu.

Rozwiązanie

Ten problem został rozwiązany w następujących zbiorczych aktualizacjach programu SQL Server:

Zbiorcza aktualizacja 5 dla programu SQL Server 2016 RTM

Zbiorcza aktualizacja 2 dla programu SQL Server 2016 z dodatkiem SP1

Zbiorcza aktualizacja 4 dla programu SQL Server 2014 z dodatkiem SP2

Zbiorcza aktualizacja 11 dla programu SQL Server 2014 z dodatkiem SP1

Zbiorcza aktualizacja 7 dla programu SQL Server 2012 z dodatkiem Service Pack 3

Każda nowa Zbiorcza aktualizacja programu SQL Server zawiera wszystkie poprawki hotfix i poprawki zabezpieczeń uwzględnione w poprzedniej aktualizacji zbiorczej. Zapoznaj się z najnowszymi aktualizacjami zbiorczymi dla programu SQL Server:

Najnowsza Zbiorcza aktualizacja dla programu SQL Server 2016

Najnowsza Zbiorcza aktualizacja dla programu SQL Server 2014

Najnowsza Zbiorcza aktualizacja dla programu SQL Server 2012 z dodatkiem SP3

Obejście

Aby obejść ten problem po zmianie typu danych, ustaw duże typy wartości poza wierszem na 1.

ALTER TABLE TableName ALTER COLUMN COLUMN_NAME nvarchar(max) NOT NULL 
go
exec sp_tableoption 'TableName', 'large value types out of row', '1'

Stan

Firma Microsoft potwierdziła, że jest to problem występujący w produktach firmy Microsoft wymienionych w sekcji "dotyczy".

Informacje

Dowiedz się więcej o terminologii używanej przez firmę Microsoft do opisywania aktualizacji oprogramowania.

Potrzebna dalsza pomoc?

Rozwijaj swoje umiejętności
Poznaj szkolenia
Uzyskuj nowe funkcje w pierwszej kolejności
Dołącz do niejawnych testerów firmy Microsoft

Czy te informacje były pomocne?

Jak zadowalająca jest jakość tłumaczenia?

Co wpłynęło na Twoje wrażenia?

Czy chcesz przekazać jakieś inne uwagi? (Opcjonalnie)

Dziękujemy za opinię!

×