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

добавления строк в 2-е таблицы(MS SQL Server 2000)

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





СообщениеДобавлено: Пт Май 07 2004 18:30    Заголовок сообщения: добавления строк в 2-е таблицы(MS SQL Server 2000) Ответить с цитатой

люди научите как правильно сделать.

Есть 2-е таблицы:
C одинаковыми ключами, тип связи 1-н ко 1-му. Необходимо за раз добавлять значение ключа в 2-е таблицы, с первичным и вторичным ключем, как это сделать, ведь sql server 2000 позволяет за раз делать запрос на добавление только в 1-у таблицу?
Значение ключа при добавлении данных в таблицу с первичным ключем инкрементируется(тип 1-го ключа Integer).
Вернуться к началу
glory



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

СообщениеДобавлено: Сб Май 08 2004 04:29    Заголовок сообщения: Ответить с цитатой

Это можно сделать с помощью Stored Procedure. Пример для двух таблиц. У каждой из таблиц поле id - ключевое. Таблицы связаны по этому полю связью один к одному. У таблицы Tab1 ключевое поле - счетчик.

Первая таблица:

Tab1(
id int (счетчик),
val1 nvarchar(10)
)

Вторая таблица:

Tab2(
id int,
val1 nvarchar(10)
)

Процедура:

CREATE PROCEDURE spInsertData
@val1 nvarchar(10),
@val2 nvarchar(10),
@id int OUTPUT
AS

INSERT INTO Tab1 (val1) VALUES (@val1)
Set @id = SCOPE_IDENTITY()
INSERT INTO Tab2 (id,val2) VALUES (@id,@val2)

GO

То есть вводятся данные в первую таблицу. Потом с помощью SCOPE_IDENTITY() возвращается последнее значение счетчика (то есть введенное значение в поле id) в переменную @id и затем вводятся данные во вторую таблицу.

Удачи.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
nova5
Гость





СообщениеДобавлено: Сб Май 08 2004 11:57    Заголовок сообщения: Ответить с цитатой

А INSTEAD OF TRIGGER на вставку не легче сделать, зачем так сложно!?
Вернуться к началу
RXLayer
Гость





СообщениеДобавлено: Вс Май 09 2004 00:46    Заголовок сообщения: Ответить с цитатой

glory и nova5 огромнейшее спасибо вам за советы!!!
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...