Q&A - К вопросу об идентификаторах
От: Иван Бодягин Австрия http://rsdn.ru
Дата: 19.02.04 10:23
Оценка: 262 (14)
Статья:
Q&A — К вопросу об идентификаторах
Автор(ы): Иван Бодягин
Дата: 07.02.2004
Уникальная идентификация записей в таблице, является практически основой реляционных СУБД. Вообще в реляционной теории предполагается, что если две записи ни чем друг от друга не отличаются, то это явная избыточность, и количество таких записей можно сократить до одной. Собственно вопросам этой самой идентификации, каковых возникает на удивление много, и посвящен этот FAQ.


Авторы:
Иван Бодягин

Аннотация:
Уникальная идентификация записей в таблице, является практически основой реляционных СУБД. Вообще в реляционной теории предполагается, что если две записи ни чем друг от друга не отличаются, то это явная избыточность, и количество таких записей можно сократить до одной. Собственно вопросам этой самой идентификации, каковых возникает на удивление много, и посвящен этот FAQ.
Мы уже победили, просто это еще не так заметно...
Re: BUG
От: Tom Россия http://www.RSDN.ru
Дата: 04.10.04 10:27
Оценка: 22 (1)

DECLARE @Page int, @PageSize int, @MaxRecord varchar(10), @Count varchar(10)

-- номер страницы
SET @Page = 100

-- размер страницы
SET @PageSize = 20

SET @MaxRecord = cast((@Page * @PageSize + @PageSize) as varchar(10))
SET @Count = cast(@PageSize as varchar(10))

EXECUTE ('SELECT * FROM
(SELECT TOP ' + @Count + ' * FROM
(SELECT TOP ' + @MaxRecord + ' * FROM sysobjects
ORDER BY name ASC) SO1
ORDER BY name DESC) SO2
ORDER BY name')


В данном коде есть баг (фича? ). Если номер страницы указать больше, чем есть данных, то возвращается всё равно последняя страница, а не пустая выборка. Это не очень удобно, когда paging делается без предварительной выборки кол-ва записей, а используя возвращённое кол-во записей.
Народная мудрось
всем все никому ничего(с).
Re: Q&A - К вопросу об идентификаторах
От: Аноним  
Дата: 24.05.04 14:15
Оценка: 20 (1)
Здравствуйте, Иван Бодягин, Вы писали:

ИБ>Статья:


Боюсь, в следующем фрагменте Вы допустили фактическую ошибку — малозначимую в контексте статьи, но тем не менее..

Oracle
Здесь можно отделаться более простым запросом, но тоже не совсем тривиальным. Эта СУБД дает некоторый доступ к своей внутренней информации, и внутри у нее записи пронумерованы. Но проблема в том, что сервер нумерует строки для своих нужд до сортировки, поэтому приходится делать вложенный запрос с сортировкой.

SELECT RowNum, U.* FROM
(SELECT * FROM user_tables ORDER BY tablespace_name) U

Такое впечатление, что Вы путаете оракловые понятия rowid и rownum. rowid — это не "внутри записи пронумерованы", но в первом приближении похожая вещь. По сути, это закодированный адрес записи в файлах БД. Что касается rownum, он никак не связан с нумерацией записей "внутри". Просто, формируя dataset (отрабатывая выражения в select-части), сервер может пронумеровать возвращаемые строки. Смысла в этом обычно действительно немного — хотя, для генерации какого-нибудь html может оказаться полезным.
Re[2]: Bug N2 (feature) с последней страницей?
От: IB Австрия http://rsdn.ru
Дата: 16.02.07 08:29
Оценка: 12 (1)
Здравствуйте, Grenal, Вы писали:

G>В последнем примере:

Для MSSQL 2005 пэйджинг вообще лучше всего делать так:
WITH Numbered (
         SELECT ROW_NUMBER() OVER(ORDER BY <стобец для сортировки>) N_Row, * FROM <таблица для пейджинга> )
SELECT * FROM Numbered WHERE N_Row between <начальная запись> AND <конечная запись>
... << RSDN@Home 1.2.0 alpha rev. 673>>
Мы уже победили, просто это еще не так заметно...
Re[4]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 20.02.04 08:18
Оценка: +1
Здравствуйте, Аноним, Вы писали:

А> вот еще бы в статьи про блокировки&эскалацию упомянули бы реализацию оракла и у Gt_ бы наступило счастье

А смысл? Её там нет, по ряду объективных причин, хотя очевидно, не помешала бы.

А>а какие еще варианты кроме sequence и автоикремента ?

Ну во-первых сиквенсы тоже разные бывают.
А во вторых есть еще IB'шные генераторы, Субэйсовский IDENTITY, который совершенно по другим принципам работает, Access'овский автоинкремент, на который без слез не взглянешь и так далее... Вообщем есть где развернуться.
Там такой зоопарк — двух одинаковых реализаций не встретишь, только ключевые слова отчасти пересекаются.
Мы уже победили, просто это еще не так заметно...
Re[4]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 21.02.05 15:39
Оценка: +1
Здравствуйте, altmenn, Вы писали:

A>???

A>He-a...He получается
Что именно не получается?
create table bb(a int)
alter table bb add b int identity

Все работает...
А вот изменить уже существующий столбец, добавив ему identity не получится.
... [ RSDN@Home 1.1.4 rev 302 ]
Мы уже победили, просто это еще не так заметно...
Re: Q&A - К вопросу об идентификаторах
От: Евгений Коробко  
Дата: 19.02.04 13:16
Оценка:
С одной стророны, узнал из статьи кое-что новое для себя, за это автору спасибо. А с другой — ничего не сказано про уникальную идентификацию в других бд! Термин sequence вообще не был упомянут, хотя сиквенсы используются в большинстве БД.
Евгений Коробко
Re[2]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 19.02.04 13:31
Оценка:
Здравствуйте, Евгений Коробко, Вы писали:

ЕК> А с другой — ничего не сказано про уникальную идентификацию в других бд! Термин sequence вообще не был упомянут, хотя сиквенсы используются в большинстве БД.

Если есть желание дописать — велкам. Присылайте на адрес в профайле doc'и в формате RSDN ML
Автор(ы): The RSDN Group
Дата: 27.10.2002
, я дополню и включу в соавторы.
У каждого сервера куча нюансов, все описывать одному — замаешься.
Мы уже победили, просто это еще не так заметно...
Re[3]: Q&A - К вопросу об идентификаторах
От: Аноним  
Дата: 19.02.04 16:04
Оценка:
ЕК>> А с другой — ничего не сказано про уникальную идентификацию в других бд! Термин sequence вообще не был упомянут, хотя сиквенсы используются в большинстве БД.

оракл упоминается — уже хорошо, вот еще бы в статьи про блокировки&эскалацию упомянули бы реализацию оракла и у Gt_ бы наступило счастье

M>Если есть желание дописать — велкам. Присылайте на адрес в профайле doc'и в формате RSDN ML
Автор(ы): The RSDN Group
Дата: 27.10.2002
, я дополню и включу в соавторы.

M>У каждого сервера куча нюансов, все описывать одному — замаешься.

а какие еще варианты кроме sequence и автоикремента ?

Gt_
Re[4]: Q&A - К вопросу об идентификаторах
От: lazymf Россия  
Дата: 20.02.04 06:34
Оценка:
Здравствуйте, <Аноним>, Вы писали:

А>а какие еще варианты кроме sequence и автоикремента ?


GUID.
silent
Re[3]: Q&A - К вопросу об идентификаторах
От: Евгений Коробко  
Дата: 20.02.04 07:55
Оценка:
А вам выслал текст про сиквенсы.
Евгений Коробко
Re[4]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 20.02.04 08:46
Оценка:
Здравствуйте, Евгений Коробко, Вы писали:

ЕК>А вам выслал текст про сиквенсы.

Да, я получил, но если честно, то даже на набросок не тянет... Во-первых Oracle И Postgree лучше разделить, сиквенсы там все-таки отличаются. и есть замечания даже по тому небольшому тексту.
Я вечером отпишу подробнее...
Мы уже победили, просто это еще не так заметно...
Re[5]: Q&A - К вопросу об идентификаторах
От: Евгений Коробко  
Дата: 20.02.04 13:05
Оценка:
Это не статья, это некоторое дополнение. А работа с сиквенсами практически идентично в Oracle и PostgreSQL
Евгений Коробко
Re: Q&A - К вопросу об идентификаторах
От: Banch  
Дата: 02.04.04 12:16
Оценка:
Здравствуйте, Иван Бодягин, Вы писали:

ИБ>Упростить постраничный вывод вряд ли возможно. Существуют СУБД, в которых введен специальный синтаксис для вывода данных постранично, но это не более чем syntactic sugar, так как производятся те же действия, что и в примерах выше, просто часть реализации остается за кадром.


я тут уже спорил по поводу постраничного вывода, но все-таки не удержался от возражений по поводу этого абзаца

рассмотрим такую задачу:
надо написать web-админ для сайтов, чтобы он мог работать с несколькими типами баз

выбор языка и средств в свете предыдущей проблемы не имеет значения

возникает вопрос, как организовать постраничный вывод для разных видов информации?
для новостей, статей, пользователей, ...

логично сделать промежуточный слой доступа к базе, в него будет передаваться запрос, номер и размер страницы; возвращаться должен resultset и общее количество записей

вариант как должен поступать код для разных баз данных:
MS SQL:
1 — добавляем TOP после SELCT и при чтении выкидываем первые ненужные записи
(разбор запроса и орагизация тройного select не беру — слишком сложно автоматически разбирать и перестраивать запрос)
2 — заменяем все между SELECT и FROM на count(*)
минусы: надо проматывать первые записи руками и делать второй запрос
(если работаем в .Net, то первые записи вообще придется качать на клиента)

MySql
1 — добавляем SQL_CALC_FOUND_ROWS после SELECT и в конец запроса дописываем LIMIT Page, PageSize
2 — берем общее число записей функцией FOUND_ROWS()
плюсы: минимальные изменения в тексте запроса, второй запрос вообще не нужен
(самый удобный способ не только для меня, но и для сервера, потому что он сможет сделать всякие оптимизации запроса)

Oracle
1 — открываем курсор, проматываем первые ненужные записи, читаем страницу
2 — заменяем все между SELECT и FROM на count(*)
плюсы: в первом случае нет изменений текста запроса
минусы: серверный курсор несколько дороговат для такой операции
и опять же изменения запроса в пункте 2

еще вариант:
можно в промежуточный слой передавать не запрос, а некий объект с параметрами того, что нужно вытащит — эдакий конструктор запросов, тогда отпадает необходимость в перелопачивании текста запроса — нам и так все известно, просто собираем то что нам нужно
но в таком случае теряется гибкость SQL, потому что любой построитель беднее самого языка

вот такие соображения
Re[2]: Q&A - К вопросу об идентификаторах
От: _MarlboroMan_ Россия  
Дата: 02.04.04 13:17
Оценка:
Здравствуйте, Banch, Вы писали:

если ты админ (а речь насколько я понимаю именно про них, и простых смертных мы не трогаем) и готов мириться с потерей производительности (а она всегда будет при реализации универсальных решений) то вот тебе способ — качай всё на клиента и уж на клиенте резвись как хочешь. если неохота, то есть универсальный (в рамках SQL-92) способ пронумеровать набор данных (и постраничный вывод становится делом техники) — танцуй от него.

задача определяет инструмент решения задачи ... чтож тут такого??? тут либо шашечки, либо ехать...
... << RSDN@Home 1.1.3 beta 1 >>

— сколько программистов надо чтобы заменить сгоревшую лампочку?
— сколько не бери, а лампочку не поменять — проблема аппаратная, программным путем не решается...
Re[2]: Q&A - К вопросу об идентификаторах
От: Аноним  
Дата: 02.04.04 18:26
Оценка:
В египте интернет дурацкии поетому критика потом будет...




Merle
Re[2]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 15.04.04 09:37
Оценка:
Здравствуйте, Banch, Вы писали:

B>логично сделать промежуточный слой доступа к базе, в него будет передаваться запрос, номер и размер страницы; возвращаться должен resultset и общее количество записей

Ну... Немного не так.
Собственно практически классика — промежуточный слой состоит из...
1ый слой: Функция возвращающая бизнес-объект, не важно, просто объект, список объектов, класс, еще что-то. В обязанности этого слоя не входит непосредственное обращение к базе он выполняет некоторые внутренние преобразования и проверки. Даже если никаких проверок не надо и получить объект можно непосредственно из базы, все равно все внешние запросы должны идти через этот промежуточный слой.
2й слой: Функция выполняющая непосредственный запрос к базе, и получающая реляционные данные.
Соответственно никаких запросов передавать не надо. Из вне идет только вызов функции возвращающий нужный бизнес-объект, с указанием номера страницы и, возможно, количества записей на страницу.

Сам запрос находится либо в хранимке, либо в коде функции обращающейся непосредственно к базе. Нет никаких проблем подставить в запрос нужные параметры для получения необходимого диапазона записей.


B>вариант как должен поступать код для разных баз данных:

B>MS SQL:
Ну собственно вариантов запросов к MSSQL'ю больше двух и они описаны в статье..

B>(если работаем в .Net, то первые записи вообще придется качать на клиента)

Не а, ничего качать не придется..

B>(самый удобный способ не только для меня, но и для сервера, потому что он сможет сделать всякие оптимизации запроса)

Как я уже говорил — просто писать меньше, то есть не более чем syntactic sugar, причем не всегда удачный. Ни каких оптимизаций сервер не применяет. Возможно теоретически они и могут быть, но пока что о таковых мне не известно.
Мы уже победили, просто это еще не так заметно...
Re[3]: Q&A - К вопросу об идентификаторах
От: Banch  
Дата: 15.04.04 17:49
Оценка:
Здравствуйте, Merle, Вы писали:

M>Сам запрос находится либо в хранимке, либо в коде функции обращающейся непосредственно к базе.

проблема возникает когда нет строго очерченных бизнес объектов
могут добавляться новые, причем в требованиях указано — без написания спец кода (хранимок и прочего ...)

M>Ну собственно вариантов запросов к MSSQL'ю больше двух и они описаны в статье..

эт поняно
я привел наиболее мне подходящий

B>>(если работаем в .Net, то первые записи вообще придется качать на клиента)

M>Не а, ничего качать не придется..
ADO.NET поступает именно так — выкачивает весь resultset на клиента
я это читал в RSDN журнале и сам видел по тестам
или я ошибаюсь?

M>Ни каких оптимизаций сервер не применяет. Возможно теоретически они и могут быть, но пока что о таковых мне не известно.

7.2.10 How MySQL Optimizes LIMIT
Re[4]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 15.04.04 18:29
Оценка:
Здравствуйте, Banch, Вы писали:

B>проблема возникает когда нет строго очерченных бизнес объектов

B>могут добавляться новые, причем в требованиях указано — без написания спец кода (хранимок и прочего ...)
Это уже совсем другая задача. К тому же что есть "спец код"? Ничто не мешает писать те же заросы в обычном коде точно таким же образом.
Да и вообще, СУБД к подобным задачам, с импровизацией на вольную тему, в принципе очень плохо приспособлены, особенно блокировочники.

B>ADO.NET поступает именно так — выкачивает весь resultset на клиента

B>я это читал в RSDN журнале и сам видел по тестам
B>или я ошибаюсь?
Ну, если в тупую использовать ADO.NET, то конечно. Нет, я имел вииду, что надо использовать запросы описаные в статье. При этом ничего лишнего на клиента не отправляется.

B>7.2.10 How MySQL Optimizes LIMIT

Ну нет...
Все эти оптимизации не выходят за рамки того же TOP в MSSQL'е, и даже наоборот — TOP по умнее будет. Так что еще раз повторюсь, MySQL'евский LIMIT — это всего лишь синтаксис.
... [RSDN@Home 1.1.3 stable]
Мы уже победили, просто это еще не так заметно...
Re[2]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 24.05.04 18:49
Оценка:
Здравствуйте, <Аноним>, Вы писали:

А>Просто, формируя dataset (отрабатывая выражения в select-части), сервер может пронумеровать возвращаемые строки.

Ну, примерно это я и имел ввиду, просто не очень четко сформулировал.
В любом случае, спасибо за поправку..
... [RSDN@Home 1.1.3 stable]
Мы уже победили, просто это еще не так заметно...
Re: Q&A - К вопросу об идентификаторах
От: Mystic Украина http://mystic2000.newmail.ru
Дата: 04.10.04 12:14
Оценка:
Здравствуйте, Иван Бодягин, Вы писали:

Немного критики.

1. Основной упор в изложении статьи делается на MS SQL server. Я никоим образом не считаю себя специалистом по Oracle, но у меня создалось такое впечатление, что про факты об Oracle упоминается скорее обзорно. Идентификация записей (rowid) присутствует и в Oracle, но об этом ничего не сказано. Для нумерации в Oracle удобно использовать аналитические функции, например:

SELECT 
  row_number() over (order by tablespace_name) as rownumber, 
  U.* 
FROM user_tables U 
ORDER BY tablespace_name


2.

Вообще в реляционной теории предполагается, что если две записи ни чем друг от друга не отличаются, то это явная избыточность, и количество таких записей можно сократить до одной.


В реляционной теории рассматривается множество кортежей (строк) отношения (таблицы), а добавление кортежа в отношение суть операция объединения множеств. Поэтому проблема дубликатов невозможна в принципе, а о сокращении, имхо, говорить несколько некорректно.

С точки зрения программиста MS SQL статья несомненно полезна.
Re[2]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 04.10.04 12:49
Оценка:
Здравствуйте, Mystic, Вы писали:

M>1. Я никоим образом не считаю себя специалистом по Oracle, но у меня создалось такое впечатление, что про факты об Oracle упоминается скорее обзорно.

Да это вообщем-то и не скрывалось.
Этот FAQ задумывался как расширяемый по разным серверам, если у кого вдруг возникнет такое желание. Возиться с Ораклом было откровенно лень.

M> Идентификация записей (rowid) присутствует и в Oracle, но об этом ничего не сказано.

Там много про что не сказано.

M>Для нумерации в Oracle удобно использовать аналитические функции, например:

Можно, было бы желание.
Расписывать все это дело можно долго и с удовольствием, но пока должным уровнем энтузиазма никто не запасся.

M>В реляционной теории рассматривается множество кортежей (строк) отношения (таблицы), а добавление кортежа в отношение суть операция объединения множеств. Поэтому проблема дубликатов невозможна в принципе, а о сокращении, имхо, говорить несколько некорректно.

Строго говоря — верно, но одной из задачь было изложить как можно проще, чтобы пагубно не повлиять на неокрепшие умы. И с этой точки зрения формулировка, думаю, вполне корректна... В крайнем случае можно изменить на "... с точки зрения вселенского Дао ..."

M>С точки зрения программиста MS SQL статья несомненно полезна.

Да она вообще полезна, судя по количеству вопросов на эту тему в форуме.
... [ RSDN@Home 1.1.4 revision 142 ]
Мы уже победили, просто это еще не так заметно...
Re[2]: BUG
От: _d_m_  
Дата: 04.10.04 22:17
Оценка:
Здравствуйте, Tom, Вы писали:

Tom>

Tom>DECLARE @Page int, @PageSize int, @MaxRecord varchar(10), @Count varchar(10)

Tom>-- номер страницы
Tom>SET @Page = 100

Tom>-- размер страницы
Tom>SET @PageSize = 20

Tom>SET @MaxRecord = cast((@Page * @PageSize + @PageSize) as varchar(10))
Tom>SET @Count = cast(@PageSize as varchar(10))

Tom>EXECUTE ('SELECT * FROM
Tom> (SELECT TOP ' + @Count + ' * FROM
Tom> (SELECT TOP ' + @MaxRecord + ' * FROM sysobjects
Tom> ORDER BY name ASC) SO1
Tom> ORDER BY name DESC) SO2
Tom> ORDER BY name')


Tom>В данном коде есть баг (фича? ). Если номер страницы указать больше, чем есть данных, то возвращается всё равно последняя страница, а не пустая выборка. Это не очень удобно, когда paging делается без предварительной выборки кол-ва записей, а используя возвращённое кол-во записей.


Да нет здесь ни бага ни фичи — топ так и должен работать. Топ означет "не больше чем". Такой метод постраничной выборки приводит к тому, что с увеличением номера страницы увеличивается промежуточный результирущий набор, а это не есть гуд.
Я бы реализовал постраничную выборку по другому: отказался от номеров страниц, а опорной точкой служило бы последнее значение уникального ключа (здесь — name), выбранного со страницы. Или же первое значение ключа, если двигаемся назад.

Выборка следующей страницы выглядела бы так (псевдокод):
select top @PageSize
    *
from
    sysobjects as so
where
    so.name > [последнее значение name на тек. странице]
order by
    so.name

Выборка предыдущей:
select
    *
from
    (select top @PageSize
        *
    from
        sysobjects as so
    where
        so.name < [первое значение name на тек. странице]
    order by
        so.name desc
    ) as Page
order by
    Page.name
Re: Q&A - К вопросу об идентификаторах
От: altmenn Германия DLR IPA
Дата: 15.02.05 10:42
Оценка:
Здравствуйте, Иван Бодягин, Вы писали:

ИБ>Статья:



ИБ>Авторы:

ИБ> Иван Бодягин

ИБ>Аннотация:

ИБ>Уникальная идентификация записей в таблице, является практически основой реляционных СУБД. Вообще в реляционной теории предполагается, что если две записи ни чем друг от друга не отличаются, то это явная избыточность, и количество таких записей можно сократить до одной. Собственно вопросам этой самой идентификации, каковых возникает на удивление много, и посвящен этот FAQ.

You wrote>>Ключевое слово IDENTITY может быть указано при создании CREATE TABLE, или изменении таблицы ALTER TABLE

Вот понадобилось всавить Identity после создания таблицы... и без промежуточного удаления и нового создания таблицы...ТО есть используя Alter Table...А как – не знаю... Может кто знает . возможно жто вообще или в статье ошибка? Если возможно...помогите примером типа :

ALTER TABLE SET Ident_table (ID int IDENTITY(1, 1), some_values varchar(50))...
Безвыходных ситуаций не бывает!(Правило Кирхгофа)
Re[2]: Q&A - К вопросу об идентификаторах
От: Sinclair Россия https://github.com/evilguest/
Дата: 15.02.05 10:57
Оценка:
Здравствуйте, altmenn, Вы писали:
A>You wrote>>Ключевое слово IDENTITY может быть указано при создании CREATE TABLE, или изменении таблицы ALTER TABLE

A>Вот понадобилось всавить Identity после создания таблицы... и без промежуточного удаления и нового создания таблицы...ТО есть используя Alter Table...А как – не знаю...

Ну так надо же все-таки в доки иногда глядеть.
Еолонка identity добавляется в существующую таблицу следующим образом:
alter table <table_name> add <column_name> int identity
... << RSDN@Home 1.1.4 beta 4 rev. 303>>
Уйдемте отсюда, Румата! У вас слишком богатые погреба.
Re[3]: Q&A - К вопросу об идентификаторах
От: altmenn Германия DLR IPA
Дата: 21.02.05 15:17
Оценка:
Здравствуйте, Sinclair, Вы писали:

S>Здравствуйте, altmenn, Вы писали:

A>>You wrote>>Ключевое слово IDENTITY может быть указано при создании CREATE TABLE, или изменении таблицы ALTER TABLE

A>>Вот понадобилось всавить Identity после создания таблицы... и без промежуточного удаления и нового создания таблицы...ТО есть используя Alter Table...А как – не знаю...

S>Ну так надо же все-таки в доки иногда глядеть.
S>Еолонка identity добавляется в существующую таблицу следующим образом:
S>
S>alter table <table_name> add <column_name> int identity
S>


???
He-a...He получается
Безвыходных ситуаций не бывает!(Правило Кирхгофа)
Re[5]: Q&A - К вопросу об идентификаторах
От: altmenn Германия DLR IPA
Дата: 22.02.05 07:38
Оценка:
Здравствуйте, Merle, Вы писали:

M>Здравствуйте, altmenn, Вы писали:


A>>???

A>>He-a...He получается
M>Что именно не получается?
M>
M>create table bb(a int)
M>alter table bb add b int identity
M>

M>Все работает...
M>А вот изменить уже существующий столбец, добавив ему identity не получится.

вот и я о том же...
А в Enterprise Manager — всеrо один ComboBox...
Безвыходных ситуаций не бывает!(Правило Кирхгофа)
Re[6]: Q&A - К вопросу об идентификаторах
От: Merle Австрия http://rsdn.ru
Дата: 22.02.05 07:48
Оценка:
Здравствуйте, altmenn, Вы писали:

A>вот и я о том же...

Дык так и надо спрашивать...

A>А в Enterprise Manager — всеrо один ComboBox...

EM, по этому комбобоксу, создает временную таблицу, выгружает в нее данные из столбца, грохает столбец, создает такой же но identity, выставляет SET IDENTITY_INSERT в ON, заливает данные из временной таблицы обратно и, наконец, ставит IDENTITY_INSERT в OFF.
Вообще в EM есть нарошная кнопка, по которой можно получить непосредственно скрипт, который выполняет EM для своих манипуляций, ну или профайлером можно отследить... Очень полезная штука для самообразования.
... [ RSDN@Home 1.1.4 rev 302 ]
Мы уже победили, просто это еще не так заметно...
Re: Bug N2 (feature) с последней страницей?
От: Grenal  
Дата: 16.02.07 08:19
Оценка:
Здравствуйте, Иван Бодягин, Вы писали:
...
В последнем примере:

SELECT * FROM
(SELECT TOP (@PageSize) * FROM
    (SELECT TOP (@Page * @PageSize + @PageSize) * FROM sys.objects 
     ORDER BY name ASC) SO1
  ORDER BY name DESC) SO2
ORDER BY name

при числе записей не кратном @PageSize на ПОСЛЕДНЮЮ страницу попадают последние @PageSize записей.
Т.е. если, допустим, всего 16 записей, а @PageSize=15, то
для Page N0 даипазон rowIndex=[0..14] , и
для Page N1 даипазон rowIndex=[1..15].

В моем случае номер записи, который я показываю пользователю, выводится как @Page * @PageSize+Индекс_записи_на_странице, т.е.
для приведенного примера запись с rowIndex=3 на нулевой странице отобразится как третья, а на последней, как 15+2=16.
Таким образом, уникальность индекса нарушается

Возможно это не баг, а фича. Или я неправильно вычисляю индекс для отображения пользователю, но в любом случае, стоит явно упомянуть о такой особенности работы запроса.
@@DBTS
От: снежок Россия  
Дата: 16.02.07 09:24
Оценка:
Здравствуйте, Иван Бодягин, Вы писали:
ИБ>Текущее значение счетчика в базе данных хранится в переменной @@DBTS.
Тем не менее, получать значение при добавлении/изменении записи с помощью переменной @@DBTS не рекомендуется в виду той же проблемы с identity, когда мы используем SCOP_IDENTITY вместо @@IDENTITY. Для timestamp отсутствует аналог SCOP_IDENTITY, поэтому, во избежании проблем, приходится делать select timestampField from tbl where ID=@ID.
В MSSQL2005 поэффективнее — можно использовать OUTPUT INSERTED.timeStampField.
... << RSDN@Home 1.1.4 stable SR1 rev. 568>>
нерассмотренный вопрос
От: снежок Россия  
Дата: 16.02.07 09:36
Оценка:
Также не рассмотрен вопрос о реализации сквозной нумерации в отсоединенных приложениях.
Я имею ввиду решения на основе пула идетификаторов, их захвата и возвращения неиспользованных обратно в пул.
... << RSDN@Home 1.1.4 stable SR1 rev. 568>>
Re: нерассмотренный вопрос
От: _d_m_  
Дата: 16.02.07 10:38
Оценка:
Здравствуйте, снежок, Вы писали:

С>Также не рассмотрен вопрос о реализации сквозной нумерации в отсоединенных приложениях.

С>Я имею ввиду решения на основе пула идетификаторов, их захвата и возвращения неиспользованных обратно в пул.

Я что-то сегодня непонятливый какой-то. Где и кем не рассмотрен?
Re[2]: нерассмотренный вопрос
От: снежок Россия  
Дата: 16.02.07 10:53
Оценка:
С>>Также не рассмотрен вопрос о реализации сквозной нумерации в отсоединенных приложениях.
С>>Я имею ввиду решения на основе пула идетификаторов, их захвата и возвращения неиспользованных обратно в пул.
___>Я что-то сегодня непонятливый какой-то. Где и кем не рассмотрен?
Автором в статье
... << RSDN@Home 1.1.4 stable SR1 rev. 568>>
Re: нерассмотренный вопрос
От: IB Австрия http://rsdn.ru
Дата: 16.02.07 11:02
Оценка:
Здравствуйте, снежок, Вы писали:

С>Также не рассмотрен вопрос о реализации сквозной нумерации в отсоединенных приложениях.

С>Я имею ввиду решения на основе пула идетификаторов, их захвата и возвращения неиспользованных обратно в пул.
Ну так рассмотри, в чем проблема?
... << RSDN@Home 1.2.0 alpha rev. 673>>
Мы уже победили, просто это еще не так заметно...
 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.