У меня есть существующая таблица, которую я собираюсь уничтожить, потому что я не создавал ее с ID
набором столбцов в качестве столбца Identity таблицы.
Используя SQL Server Management Studio , я написал сценарий «Создать в ...» существующей таблицы и получил следующее:
CREATE TABLE [dbo].[History](
[ID] [int] NOT NULL,
[RequestID] [int] NOT NULL,
[EmployeeID] [varchar](50) NOT NULL,
[DateStamp] [datetime] NOT NULL,
CONSTRAINT [PK_History] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
Мой вопрос: как мне изменить это, SQL
чтобы в моей результирующей таблице ID
столбец был установлен как Identity ?
sql
sql-server
tsql
jp2code
источник
источник
Ответы:
источник
PK_History
значение наID
что-нибудь?На это уже был дан ответ, но я думаю, что самый простой синтаксис:
Более сложный индекс ограничения полезен, когда вы действительно хотите изменить параметры.
Кстати, я предпочитаю называть такой столбец HistoryId, чтобы он соответствовал именам столбцов во взаимосвязях внешнего ключа.
источник
ID int constraint PK_History primary key identity(1,1)
Я считаю.NOT NULL
избыточно.конечно, поскольку вы создаете таблицу в SQL Server Management Studio, вы можете использовать конструктор таблиц для установки спецификации идентификации.
источник
Уникальный ключ допускает максимум 2 значения NULL. Объяснение:
Если вы попробуете вставить те же значения, что и ниже:
Каждый раз вы будете получать такую ошибку:
источник
ID
столбец , а не столбец. Почему вы добавили уникальное ограничение в столбец? Какую пользу это принесет вам в вашем столе?Name
Name
teppp