4972: Fehler bei der ALTER TABLE SWITCH-Anweisung.
Fehlermeldung:
Meldung 4972, Ebene 16, Status 1, Zeile 2
Fehler bei der ALTER TABLE SWITCH-Anweisung. CHECK-Einschränkungen oder die Partitionsfunktion der '%1!'-Quelltabelle lassen Werte zu, die von CHECK-Einschränkungen oder der Partitionsfunktion in der '%2!'-Zieltabelle nicht zugelassen werden.
Ebene:
16.
Beschreibung:
Diese Fehlermeldung erscheint, wenn man versucht, eine ALTER TABLE SWITCH Anweisung auszuführen, bei der die Zieltabelle eine CHECK Einschränkung aufweist, die in der Quelltabelle nicht vorhanden 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. Quell- und Zieltabelle müssen identische CHECK Einschränkungen aufweisen.
Versionen:
Diese Fehlermeldung wurde mit SQL Server 2005 eingeführt.
Beispiele:
USE Pubs
GO
SET NUMERIC_ROUNDABORT OFF;
SET ANSI_PADDING,
ANSI_WARNINGS,
CONCAT_NULL_YIELDS_NULL,
ARITHABORT,
QUOTED_IDENTIFIER,
ANSI_NULLS ON;
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
)
ON myPartScheme (c1);
GO
CREATE TABLE myNonPartTable
(
c1 int
CONSTRAINT chk_myNonPartTable_c1 CHECK(c1<>0)
)
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 Zieltabelle eine CHECK Einschränkung besitzt, welche die Quelltabelle nicht aufweist, wird der Fehler ausgelöst.