Es ist möglich, einen Primärschlüssel oder einen eindeutigen Index in einer SQL Server-Anweisung CREATE TABLE zu erstellen. Ist es möglich, einen nicht eindeutigen Index innerhalb einer CREATE TABLE-Anweisung zu erstellen ?
CREATE TABLE MyTable(
a int NOT NULL
,b smallint NOT NULL
,c smallint NOT NULL
,d smallint NOT NULL
,e smallint NOT NULL
-- This creates a primary key
,CONSTRAINT PK_MyTable PRIMARY KEY CLUSTERED (a)
-- This creates a unique nonclustered index on columns b and c
,CONSTRAINT IX_MyTable1 UNIQUE (b, c)
-- Is it possible to create a non-unique index on columns d and e here?
-- Note: these variations would not work if attempted:
-- ,CONSTRAINT IX_MyTable2 INDEX (d, e)
-- ,CONSTRAINT IX_MyTable3 NONCLUSTERED INDEX (d, e)
);
GO
-- The proposed non-unique index should behave identically to
-- an index created after the CREATE TABLE statement. Example:
CREATE NONCLUSTERED INDEX IX_MyTable4 ON MY_TABLE (d, e);
GO
Wiederum besteht das Ziel darin, den nicht eindeutigen Index innerhalb der Anweisung CREATE TABLE zu erstellen, nicht danach.
Für das, was es wert ist, fand ich den [SQL Server Books Online-Eintrag für CREATE TABLE] nicht hilfreich.
Auch [Diese Frage] ist nahezu identisch, aber die akzeptierte Antwort trifft nicht zu.