Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

SQL 2000 уникальные идентификаторы

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
ron_k



Зарегистрирован: 16.02.2005
Сообщения: 2

СообщениеДобавлено: Ср Фев 16 2005 14:48    Заголовок сообщения: SQL 2000 уникальные идентификаторы Ответить с цитатой

есть ли такая переменная которая хранит значение созданного уникального идентификатора, или еще что нить но проблема следущая...

например была создана таблица table_1 (UID)
был написан триггер который копировал запись из table_1 в table_1_sh( типа теневая таблица) при каждом добавлении записи в UID...
проблема в том что он переносит ВСЕ строки...логично...
вот вопрос...как это лечится если хотелось чтобы он переносил тока ту строку, которая добавилась...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Motor



Зарегистрирован: 18.01.2005
Сообщения: 36
Откуда: Оттуда

СообщениеДобавлено: Чт Фев 17 2005 09:14    Заголовок сообщения: Ответить с цитатой

Наверное надо написать триггер, который отслеживает изменение полей в таблице.
Потом написать процедурку, которая будет эти измененые поля шлепать в таблицу синхронизации, а оттуда уже можно обновлять и твою таблицу...
_________________
Танцуют Все!
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
ron_k



Зарегистрирован: 16.02.2005
Сообщения: 2

СообщениеДобавлено: Чт Фев 17 2005 15:00    Заголовок сообщения: теневые таблицы Ответить с цитатой

Может просто подскажете как можно создать теневые таблицы или дадите сслыку где про это написано...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Ната!



Зарегистрирован: 02.11.2004
Сообщения: 4

СообщениеДобавлено: Пт Фев 25 2005 23:17    Заголовок сообщения: Ответить с цитатой

поможет следующее:

При выполнении команд добавления, изменения, удаления записей сервер создает две специальные таблицы: inserted и deleted. В них содержатся строки, которые будут вставлены или удалены по завершению транзакции. Структура таблиц inserted и deleted идентична стуктуре таблиц, для которых определяется триггер. Для каждого триггера создается свой комплект таблиц inserted и deleted, поэтому никакой другой триггер не сможет полцчить к ним доступ.
1. команда INSERT - в таблице inserted содержатся все строки, которые пользователь пытается вставить в таблицу, в таблице deleted - ни одной строки; после завершения триггера все строки из таблицы inserted переместятся в исходную таблицу.
2. команда DELETE - в inserted - ни одной строки, в deleted - все строки, которые пользователь пытается удалить.
3. команда UPDATE - в deleted - значения строк, которые будут удалены при успешном завершении триггера. Новые значения строк содержатся в inserted.

Кол-во измененных строк можно узнать -@@ROWCOUNT

Вот и все!
Желаю успехов!
Только обязательно сообщите, если все получится!
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...