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

Вниз

Реляционные БД   Найти похожие ветки 

 
Vlad_Dyachkov   (2004-08-23 14:58) [0]

Возможно вопрос чайника, но я очень поверхностно знаком с реляционными БД...

Почитал теорию реляционных баз данных и возник вопрос по поводу их практического использования. К примеру есть две таблицы:
[Authors]
-AuthorID (Int, Key, AutoInc)
-AuthorName (Str)

[Books]
-BookID (Int, Key, AutoInc)
-AuthorID (Int)
-BookName (Str)

Необходимо добавить в базу Автора и книгу на этого автора. В данный момент это делаю следующим способом:
Сначала добавляю автора:
INSERT INTO [Authors] (AuthorName) VALUES ("Лев Толстой")

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

А возможно ли одним запросом или более упрощенным способом добавлять в базу автора и сразу необходимую книгу на него?..


 
vovchik   (2004-08-23 15:09) [1]

Утверждать не буду, но мне кажется нет. Ты же сначала должен выполнить запрос и по окончанию выполнения получить значение в таблице1 по которому ты дальше вставляешь запись в другую таблицу2. Если ты напишешь один запрос на вставку записей в две таблицы, то не закончив обработку таблицы1 ты уже пихаешь данные в таблицу2 относительно значения первой, а значения то ещё не присвоились в таблице1. Ты можешь вставить данные в две таблицы если у тебя уже есть какой то ID. По крайней мере у меня не получалось делать такой трюк какой ты хотишь.


 
Карелин Артем ©   (2004-08-23 15:10) [2]

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


 
Digitman ©   (2004-08-23 15:21) [3]


> Затем иду в конец таблицы


разберись с понятием "конец таблицы" - это крайне важно


 
Vemer ©   (2004-08-23 19:58) [4]

Вариант:
Если база 1-пользовательская - получи в начале следующий номер (например Select Max(Authors_ID_Field) + 1 From Authors) в переменную, потом вставляй это значение в авторов и в книги. Так по крайней мере номер выуживать не надо.. А потом можно переменную просто увеличивать на 1, до конца "сеанса связи" :).


 
3APA3A ©   (2004-08-23 22:50) [5]

Исходя из определений
  1) РСУБД рассматривает таблицу как множество некоторых элементов
  2) У множества нет понятия "порядковый номер".
  1) + 2) Выражение "конец таблицы" не имеет смысла...



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

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

Наверх




Память: 0.48 MB
Время: 0.061 c
14-1094097894
Deniz
2004-09-02 08:04
2004.09.19
vconxx???


1-1094472756
Andrey
2004-09-06 16:12
2004.09.19
Windows XP


1-1094154898
SelloutS
2004-09-02 23:54
2004.09.19
нужен компанент для скажтия/расжатия файлов...


1-1094293233
andruxa
2004-09-04 14:20
2004.09.19
вопросы по памяти и ОС(EOSError).


4-1091777599
Ricko
2004-08-06 11:33
2004.09.19
SMS и PDU