Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Не обновляется БД 
:(
    Опции темы
1122
  Дата 22.6.2010, 06:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 109
Регистрация: 24.10.2007

Репутация: нет
Всего: нет



Есть приложение написанное на делфи в дизайн-тайме.
Пользуюсь компонентами библиотеки EhLib (DBGridEh, DBEditEh, IBXDataDriverEh, MemTableEh, DataSource и MemTableEh).
Сервер FireBird 2.0
На форму кинул IBDatabase и IBTransaction, подключил их к базе, отображение в гриде есть.
Для работы с базой использую DBNovigator.
Пытаюсь изменить информацию в базе или добавить... в гриде все добавляет и изменяет, а в базе нет, и соответственно после перезапуска приложения грид тоже сбрасывается.
Только начал изучать БД.
Подскажите плиз в чем может быть ошибка!
Спасибо! 

PM MAIL   Вверх
Frees
Дата 22.6.2010, 07:10 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2233
Регистрация: 2.12.2005
Где: Екатеринбург

Репутация: 23
Всего: 54



IBTransaction.Commit делал? 


--------------------
Кольцов Виктор Владимирович
PM MAIL ICQ   Вверх
Akella
Дата 22.6.2010, 09:37 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



1122, ты только не спрашивай, что такое транзакции и с чем их готовят  smile 

Это сообщение отредактировал(а) Akella - 22.6.2010, 09:37
PM MAIL   Вверх
Данкинг
Дата 22.6.2010, 09:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



Цитата(1122 @  22.6.2010,  07:48 Найти цитируемый пост)
Подскажите плиз в чем может быть ошибка!

В неподтверждённой транзакции. smile 


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
1122
Дата 22.6.2010, 14:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 109
Регистрация: 24.10.2007

Репутация: нет
Всего: нет



Добавил в обработчик события кнопки добавления:
Form3.IBtransaction1.commit
Все равно не работает.
Да и так пробовал:
Код

Form3.IBtransaction1.active:=false; // Если true то пишет ошибку "transaction is activ"
Form3.IBtransaction1.startTransaction;
..... // SQL запрос на добавление 
Form4.IBTransaction.commit;


Еще примечательно то, что на это же форме есть еще один грид, куда выводится отсортированная информация из таблице, куда я пытаюсь добавить. Выводится в этот грид инфа с помощью IBQuery, который обращается к базе. Из чего можно сделать вывод, что информация все же до базы дошла, но как только приложение закрывается все исчезает.

Коммит не помог :(
Или я что-то не так делаю?

Я создал для всех форм с гридами одну IBDatabase и IBTransaction на отдельной форме и везде в uses'ах подключил модуль этой формы. Эти компоненты всегда активны и связь с базой есть.
Хелп! :(
PM MAIL   Вверх
Keeper89
Дата 22.6.2010, 15:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2580
Регистрация: 26.2.2009

Репутация: 1
Всего: 58



Цитата

// Если true то пишет ошибку "transaction is activ"

Вот и зачем новую начинать? Подтвердите уже имеющуюся.


--------------------
PM MAIL WWW   Вверх
1122
Дата 22.6.2010, 16:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 109
Регистрация: 24.10.2007

Репутация: нет
Всего: нет



"Подтвердите уже имеющуюся"

Так и сделал.

Код

procedure TForm4.Button2Click(Sender: TObject);
begin
IBXDataDriverEh1.UpdateSQL.Clear;
IBXDataDriverEh1.UpdateSQL.Add('update KATALOG_TOVAROV set NAZVANIE = :NAZVANIE, CENA_ZA_EDINICU =:CENA_ZA_EDINICU, ID_PROIZVODITELIA =:ID_PROIZVODITELIA, HARAKTERISTIKA =:HARAKTERISTIKA, UPAKOVKA =:UPAKOVKA where ID =:ID');
Form3.IBTransaction1.Commit;
MemTableEh1.Refresh;
end;


Из 4-5 экспериментальных добавлений 1 (один) раз все же добавление произошло, с таким кодом!!! Не могу понять почему! Теперь я совсем в замешательстве.
Что не так в коде?

И еще... в Transaction properties надо выбрать Read commited ? У пробовал и с Read commited  и вообще без ничего. Эффект один.
PM MAIL   Вверх
Keeper89
Дата 22.6.2010, 19:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2580
Регистрация: 26.2.2009

Репутация: 1
Всего: 58



А через что происходит апдейт? Я просто не вижу выполнения запроса или связки Edit/Post.


--------------------
PM MAIL WWW   Вверх
Данкинг
Дата 22.6.2010, 20:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



А если не извращаться со всякими .UpdateSQL, а использовать обычный IBQuery?


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
Akella
Дата 23.6.2010, 14:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Советую прочитать о работе транзакций, о принципе программирования клиент-серверных приложений и как вообще работать с транзакциями. Посмотреть примеры.

Добавлено через 17 секунд
Иначе так и будет тыкаться, как слепой котёнок.

Добавлено через 49 секунд
Извини за равнение. Не ради того, чтобы обидеть или оскорбить, просто пример удачный smile
PM MAIL   Вверх
Моряк007
Дата 24.6.2010, 20:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 24.6.2010

Репутация: нет
Всего: нет



Таже проблема. Обновляется только insert, а delet и edit нет(((
Буду рад если кто подскажет. Транзакцию завершал.
PM MAIL   Вверх
Akella
Дата 25.6.2010, 08:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Цитата(Моряк007 @  24.6.2010,  20:50 Найти цитируемый пост)
Обновляется только insert, а delet и edit нет

Ты сам-то понял, что написал?
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.1231 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.