Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.05.2014, 19:54
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание FireDACQuery как избавится от автосохранения?

Всем добрый день..

Ребята кто знает как справится с FDQuery ситуация такая
жму кнопку добавить нового пользователя
открывается окно для ввода данных
Код:
procedure TForm2.FormShow(Sender: TObject);
begin
label2.Caption:=datetostr(now);
form1.FDQuery1.Insert;
form1.FDQuery1.FieldByName('date').Value:=label2.Caption;
end;

И если ничего не сделать и просто закрыть форму ввода данных то автоматом база сохраняется

FDQuery не ждет команду Post для сохранения?? это почему? что не так делаю??
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #2  
Старый 14.05.2014, 20:31
Аватар для Freeman
Freeman Freeman вне форума
Местный
 
Регистрация: 05.10.2012
Адрес: Санкт-Петербург
Сообщения: 577
Версия Delphi: 6
Репутация: выкл
По умолчанию

Цитата:
Сообщение от Electronic_Arts
FDQuery не ждет команду Post для сохранения??
Где-то в коде явно или неявно вызывается CheckBrowseMode. При закрытии формы без сохранения нужно явно отменять изменения.
__________________
Не стоит путать форумы с богадельнями. © Bargest
Ответить с цитированием
  #3  
Старый 14.05.2014, 21:00
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Я только настроил FDConnection + FDQuery даже код не начал писать

а как отменять изменения?

FDQuery.cancel ??? это не создаст проблему другим пользователям работающим на этой же базе??
__________________
Нет ничего не возможного. Вопрос только во времени...

Последний раз редактировалось Electronic_Arts, 14.05.2014 в 21:03.
Ответить с цитированием
  #4  
Старый 14.05.2014, 22:13
Аватар для Freeman
Freeman Freeman вне форума
Местный
 
Регистрация: 05.10.2012
Адрес: Санкт-Петербург
Сообщения: 577
Версия Delphi: 6
Репутация: выкл
По умолчанию

Цитата:
Сообщение от Electronic_Arts
FDQuery.cancel ??? это не создаст проблему другим пользователям работающим на этой же базе??
Могу посоветовать лишь хоть немного почитать теорию БД и DB-компонентов Delphi.
__________________
Не стоит путать форумы с богадельнями. © Bargest
Ответить с цитированием
  #5  
Старый 15.05.2014, 01:07
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

А зачем вы тогда вообще в базу что-то добавляете, если еще не определились нужно это или нет. Где логика?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #6  
Старый 15.05.2014, 22:50
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Цитата:
Сообщение от Страдалецъ
А зачем вы тогда вообще в базу что-то добавляете, если еще не определились нужно это или нет. Где логика?
Я начал работать с БД не так давно - просто первые шаги начал делать с ADO и Access локальными базами и по учебниках помню что если собираемся что то добавить то Insert а сейчас просто перешел на MySQL - и тут первые проблемы были с SQLConnection то библиотека не та то не получается ее найти вот решил пробовать FireDAC - с ним все как по маслу пошло...но вот иногда возникает вопросы а ответов не нахожу...

А как ты советуешь поступить - ведь если не использовать
Query.Insert
то как?
Просто дело в том что FireDAC все синхронизирует пока ты что то вбиваешь в DBEdit - если не отменить все (Query.cancel) при закрытии формы то они уже попадают в базу..
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
  #7  
Старый 16.05.2014, 01:17
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Вариант 1. Использовать транзакции. Что это такое и как с ними работать, вам придется поискать в инете, а там этого полно.
Вариант 2. На этапе ввода работать с временной копией данных. Как это сделать тоже вариантов масса.
Вариант 3. Настроить FireDAC для работы с пакетными операциями (Batch mode). Что это такое и как с ними работать, вам придется поискать в инете, а там этого тоже полно.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.

Последний раз редактировалось Страдалецъ, 16.05.2014 в 01:21.
Ответить с цитированием
  #8  
Старый 17.05.2014, 00:07
Аватар для Electronic_Arts
Electronic_Arts Electronic_Arts вне форума
Местный
 
Регистрация: 13.07.2006
Адрес: на земле
Сообщения: 562
Версия Delphi: Delphi 11
Репутация: 18
Восклицание

Спасибо за подсказки а то не знал кто как с чего начать...если что я еще обращусь за помощью...
__________________
Нет ничего не возможного. Вопрос только во времени...
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 14:14.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter