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

транзакции

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



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

СообщениеДобавлено: Пн Авг 09 2004 15:49    Заголовок сообщения: транзакции Ответить с цитатой

Как поступить? Из одной хранимой процедуры вызывается другая. Обе вносят изменения в БД. Как применить транзакции. Только в первой процедуре? Или еще во второй? (тогда получится в одной транзакции осуществляется другая..). Кто знает?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
wildwind



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

СообщениеДобавлено: Вт Авг 10 2004 14:07    Заголовок сообщения: Ответить с цитатой

В общем случае управлять транзакциями должен клиент.
А в твоем конкретном случае это зависит от бизнес-логики приложения. Требует ли она, чтобы все изменения внесенные и первой и второй процедурой, были согласованными?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
msfaq



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

СообщениеДобавлено: Вт Авг 10 2004 15:54    Заголовок сообщения: Ответить с цитатой

Да! Нельзя чтобы внеслись изменения только из 1 или только из 2 процедуры. Просто если транзакция начинается в первой и заканчивается в первой процедуре, то попадет ли в нее 2 процедура, вызывающаяся внутри транзакции в первой процедуре.
Или нужно в каждой процедуре свою транзакцию? Поясните пожалуйста.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
wildwind



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

СообщениеДобавлено: Вт Авг 10 2004 18:01    Заголовок сообщения: Ответить с цитатой

Вызываешь 1-ю процедуру (которая вызывает 2-ю), она отрабатывает, потом явно делаешь commit. На клиенте. Если возвращает ошибку, делаешь rollback. Во многих случаях это может гарантировано делать клиентская библиотека. Ищи в настройках параметр AUTOCOMMIT или что-то похожее.

Ты бы хоть написал, что за БД у тебя, какой интерфейс к ней, и на чем пишешь (вообще-то так принято по умолчанию).

Вставлять commit в процедуру не нужно, даже в первую; потому что она тоже может вызываться как часть какой-то транзакции (как у тебя 2-я).
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Andy-C



Зарегистрирован: 09.12.2003
Сообщения: 73
Откуда: Нальчик

СообщениеДобавлено: Чт Авг 19 2004 10:42    Заголовок сообщения: ibase.ru + Грабер Ответить с цитатой

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