4913: Fehler bei der ALTER TABLE SWITCH-Anweisung.
Fehlermeldung:
Meldung 4913, Ebene 16, Status 1, Zeile 1
Fehler bei der ALTER TABLE SWITCH-Anweisung. Die '%1!'-Tabelle hat den gruppierten Index '%2!', die '%3!'-Tabelle hat dagegen keinen gruppierten Index.
Ebene:
16.
Beschreibung:
Diese Fehlermeldung erscheint, wenn man versucht, eine ALTER TABLE SWITCH Anweisung auszuführen, bei der der gruppierte Index in Quell- und Zieltabelle unterschiedlich ist.
Auswirkungen:
Das SQL Statement kann zwar geparst werden, jedoch zur Laufzeit wird der Fehler ausgelöst.
Behebung:
Fehler der Ebene 16 sind Fehler, die vom Anwender hervorgerufen werden. Sie können und müssen vom Anwender korrigiert werden. Das Statement kann so nicht ausgeführt werden. Der gruppierte Index muss in beiden Tabellen identisch sein.
Versionen:
Diese Fehlermeldung wurde mit SQL Server 2005 eingeführt.
Beispiele:
USE Pubs
GO
CREATE PARTITION FUNCTION myPartFunction (int)
AS RANGE LEFT FOR VALUES (1, 10, 100);
GO
CREATE PARTITION SCHEME myPartScheme
AS PARTITION myPartFunction
ALL TO ([PRIMARY]);
GO
CREATE TABLE myPartTable
(
c1 int PRIMARY KEY
)
ON myPartScheme (c1);
GO
CREATE TABLE myNonPartTable
(
c1 int
)
ON [PRIMARY];
GO
ALTER TABLE myPartTable SWITCH PARTITION 1 TO dbo.myNonPartTable ;
GO
DROP TABLE myNonPartTable, myPartTable;
DROP PARTITION SCHEME myPartScheme;
DROP PARTITION FUNCTION myPartFunction;
Anmerkungen:
Im obigen Beispiel wird versucht in der ALTER TABLE SWITCH Anweisung auszuführen. Da die Quelltabelle aber mit dem Primary Key auf der Spalte c1 einen gruppierten Index aufweist, währen die Zieltabelle keinen besitzt, wird der Fehler ausgelöst.