Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.01.21;
Скачать: CL | DM;

Вниз

Поле типа Identity - как задать значение, с которого начинать нумерацию?   Найти похожие ветки 

 
fishka   (2001-12-18 12:10) [0]

В таблице есть поле типа Identity. При удалении записей из таблицы и добавлении других происходит наращивание значения в данном поле для вновь добавленных записей.
Например, были значения 1-50. Удалили записи. Добавили 35 записей. В данном поле получились значения 51-85. А хочется, чтобы были 1-35.
Как сделать, чтобы минимальным в данном поле всегда было значение 1 (не удаляя при этом таблицу)?


 
Delirium ©   (2001-12-18 12:18) [1]


ALTER TABLE My_Table DROP COLUMN column_ident
ALTER TABLE My_Table ADD column_ident Identity(1,1)


 
Delirium ©   (2001-12-18 12:30) [2]

Ошибочка - писал не проверяя, теперь правильно :)

ALTER TABLE My_Table DROP COLUMN column_ident
ALTER TABLE My_Table ADD column_ident int Identity(1,1) not null


 
TSV ©   (2001-12-18 13:13) [3]

> fishka

По этому поводу хорошо написано в Books Online. Посмотри SET IDENTITY_INSERT. Также есть пример определения "дыр" для identity-поля в таблице.

Удачи.


 
fishka   (2001-12-18 16:08) [4]

Спасибо за ответы.
>TSV
В Books Online (Transact_SQL Reference 6.0) есть ссылка на SET IDENTITY_INSERT. Но примера нет. Ничего другого найти не удалось, да еще и английского я не знаю. Подскажите, пожалуйста, в каком разделе это описано.


 
TSV ©   (2001-12-18 17:26) [5]

> fishka

Находится это дело в IDENTITY (Property) (T-SQL).
Вот сам пример:

CREATE TABLE img (id_num int IDENTITY(1,1), company_name sysname)
INSERT img(company_name) VALUES ("New Moon Books")
INSERT img(company_name) VALUES ("Lucerne Publishing")

-- SET IDENTITY_INSERT ON and use in img table.
SET IDENTITY_INSERT img ON

DECLARE @minidentval int
DECLARE @nextidentval int
SELECT @minidentval = MIN(IDENTITYCOL) FROM img
IF @minidentval = IDENT_SEED("img")
SELECT @nextidentval = MIN(IDENTITYCOL) + IDENT_INCR("img")
FROM img t1
WHERE IDENTITYCOL BETWEEN IDENT_SEED("img") AND 2147483647 AND
NOT EXISTS (SELECT * FROM img t2
WHERE t2.IDENTITYCOL = t1.IDENTITYCOL + IDENT_INCR("img"))
ELSE
SELECT @nextidentval = IDENT_SEED("img")

-- ЗДЕСЬ МОЖНО ДЕЛАТЬ ВСТАВКУ ЗАПИСИ С IDENTITY = @nextidentval

SET IDENTITY_INSERT img OFF

Удачи.



Страницы: 1 вся ветка

Текущий архив: 2002.01.21;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.008 c
7-66378
SERG_NENIA
2001-09-28 08:15
2002.01.21
как быть с организацие поиска


4-66402
ДедушкаКо
2001-11-19 14:45
2002.01.21
Из осн. удалили...не понял почему. Попробую здесь...


1-66307
Socol
2002-01-01 12:22
2002.01.21
Открытие файла


6-66321
SBad
2001-10-17 13:17
2002.01.21
Кто работал с протаколом SOAP


1-66304
BFG
2002-01-05 10:16
2002.01.21
Icon