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

Вниз

Целостность и транзакция   Найти похожие ветки 

 
adias ©   (2004-02-25 16:13) [0]

Есть 2 таблицы (А и Б).
Ключ таблицы А - ID
Ключ таблицы Б - ID1,+ поле ID1 для связи с ID1
таблицы А
****************
Транзакция.
 вставка записи в таблицу А (формирование max(ID)+1)
 вставка значения в таблицу Б (формирование max(ID1)+1)
КОНЕЦ
ТРАНЗАКЦИИ
***************************
ОПИСАНИЕ: если два юзера одновременно начнут транзакцию,
то один посылается нах... (ПРОВЕРЯЛ)
ВОПРОС: как избежать?
Примечание: пользоваться
специфическими функциями конкретной БД нельзя (там identity всякие и т.п.) и системными таблицами
тоже....


 
Sandman25+1   (2004-02-25 16:26) [1]

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


 
ADIAS ©   (2004-02-25 17:26) [2]

получается надо делать еще одну таблицу, для всякого мусора и чем (на что) блокировать транзакцию???


 
Sandman25+1   (2004-02-25 17:31) [3]

Блокировать на запись, конечно.


 
adias ©   (2004-02-25 17:50) [4]

а глупый вопрос, а как? :-((


 
Sandman25+1   (2004-02-25 17:53) [5]

Не знаю, как для MS SQL.
Для Informix это выглядело бы как
LOCK TABLE mytable IN EXCLUSIVE MODE


 
adias ©   (2004-02-26 09:06) [6]

да, но это блокирует не запись, а страницу...


 
Nikolay M. ©   (2004-02-26 10:07) [7]

Блин, сколько же можно одно и то же спрашивать?!
http://rsdn.ru/article/db/midas_migration.xml#XSLTSECTION124143120120



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

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

Наверх




Память: 0.48 MB
Время: 0.056 c
3-1077865464
Ega23
2004-02-27 10:04
2004.03.28
Ещё раз про настройки QA


14-1078064676
blackweber
2004-02-29 17:24
2004.03.28
как загрузить комп без клавиатуры?


14-1077632293
Zendor
2004-02-24 17:18
2004.03.28
Delphi 8


6-1073655406
Va
2004-01-09 16:36
2004.03.28
Как узнать, что закончилась регистрация в сети ?


14-1078216065
Kerk
2004-03-02 11:27
2004.03.28
Бойкот выборов