Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  01:03[Войти] | [Зарегистрироваться]
Ответ на вопрос № 31661

11-05-2005 12:28
Здравтсвуйте! Помогите решить проблему с триггерами в MS SQL 2000.
Есть 3 таблицы Filial (Id - автоинкрементное, Name), Race (Id - автоинкрементное, Name) и
Fil_Race (Id - автоинкрементное, Fil_Id, Race_Id, Name, Avail). Таблицы
Filial и Fil_Race  имеют общее поле для связи (Filial.Id=Fil_Race.Fil_Id), а таблицы
Race и Race имеют общее поле для связи (Race.Id=Fil_Race.Race_Id). Необходимо
создать следующий триггер на вставку новой записи в таблицу Filial.
Id всех записей таблицы Race вставить в Fil_Race со зачением нового id
таблицы Filial.
Конкретно не могу решить вопрос по получению id новой
вставленной записи в Filial и вставке значений из поля всех
записей таблицы Race.

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

12-05-2005 08:59 | Сообщение от автора вопроса
Большое спасибо. Действительно работает. Я-то думал, что
поле Id у меня автоинрементное. А щас глянул-точно, забыл сделать автоинкрементным.
Еще раз спасибо

12-05-2005 08:15
ошибка "Cannot insert the value NULL into column 'Id',
table dbo.Fil_Race; column does not allow nulls. Insert fails".


Это значит, что у тебя поле Id в табл.Fil_Race имеет ограничение NOT NULL. Тебе или нужно снять это ограничение, и тогда ты должен будешь заполнять это поле при вставке сам, или же ты сделай это поле счетчиком, и тогда оно будет наращиваться на единицу автоматически и его не надо указывать в insert.

И еще. Добавь в начале триггера эти строчки:

if @@rowcount = 0
begin
  return
end

Это защита от ложного срабатывания триггера, так всегда делается.

12-05-2005 04:22 | Сообщение от автора вопроса
Спасибо! Помогло. Но у меня добавилось условие. Если в
Fil_Race уже есть записи с добавляемым @fid, то тогда
добавлять не нужно в Fil_Race. Я пишу:

CREATE TRIGGER Filials_Insert ON [dbo].[Filials]
AFTER INSERT
AS
declare @fid int
select @fid = inserted.Id  from inserted
if not exists (select * from Fil_Race where Fil_Race.Filial_Id=@fid)
begin
insert into Fil_Race (Filial_Id, Race_Id, BeginD, EndD)  select @fid, Race.Id,
Race.BeginDate, Race.EndDate  from Race
end


Действительно, если в табл. Filial добавляется запись с
уже имеющемся в ней id (это поле не является ключом), то
ничего не происходит. А если добавляется запись с новым
id то происх. ошибка "Cannot insert the value NULL into column 'Id',
table dbo.Fil_Race; column does not allow nulls. Insert fails".
Не знаю почему может что-то не так написал?
Например табл. Filial:
Id           Name
1           aaa
1           aaa_aaa
2           bbb
2           bbb_bbb
.........................
Если сейчас добавить запись с Id=2 то триггер не сработает,
а если  с другим Id то возникнет эта ошибка.

11-05-2005 15:41
добавь

  insert into Fil_Race (Fil_Id, Race_Id)
  select @fid, Race.Id
  from Race

11-05-2005 14:36 | Сообщение от автора вопроса
Спасибо за ответ на 1 вопрос
Объясняю! Нужно взять взять все id всех записей из Race и вставить
их новые записи в таблицу Fil_Race (в поле Race_Id)
Fil_Id это будет @fid (id добавленной записи в Filial)
Т. е. есть табл. RAce:
id                     Name
1                     AAA
2                     BBB
3                     CCC
...                     ...

Нужно добавить  все эти записи в Fil_Race, чтобы появились такие записи:
...                     ....
Id                     Fil_Id           Race_Id
...                     @fid           1
...                     @fid           2
...                     @fid           3
...                     @fid           ...

Если что-то непонятно объясню еще

11-05-2005 14:08
Конкретно не могу решить вопрос по получению id новой
вставленной записи в Filial


  declare @fid int
  select @fid = inserted.Fil_Id
  from inserted

и вставке значений из поля всех
записей таблицы Race


Tут не совсем ясно, что тебе нужно. Tо ли выбрать  все записи из Race, где Race.Id=@fid и вставить их в  Filial. Tо ли выбрать вообще все записи из Race, проапдейтить Id на новое и затем вставить в Fil_Race.

Oбъясни яснеее.

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Однажды, в студеную зимнюю пору я из лесу вышел, был сильный ЧТО?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования