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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 12.06.2013, 13:59
evgenia.ini evgenia.ini вне форума
Прохожий
 
Регистрация: 12.06.2013
Сообщения: 5
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Столбец ADOQuery - 1

Помогите новичку, пожалуйста!

Программа "авиаперевозки".

На 1ой форме база данных рейсов. Я выделяю рейс, нажимаю на кнопку "Купить билет" выскакивает 3я форма, на которой нужно заполнить данные о пассажире. Нажимаю кнопку "ОК" и эти данные помещаются на 2ую форму в базу данных пассажиров.

Нужно сделать так, чтобы когда на 3ей форме нажималась кнопка "ОК", из 1ой формы (база данных рейсы) в столбце "кол-во билетов" от этого рейса отнимался один.
Ну и ещё можно, чтобы при нажатии кнопки "Удалить" пассажира из базы данных на 2ой форме, билет наоборот, прибавлялся

Вроде просто, но никак не получается..
Заранее спасибо
Ответить с цитированием
  #2  
Старый 12.06.2013, 14:06
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Что не получается, покажите пожалуйста.
Ответить с цитированием
  #3  
Старый 12.06.2013, 15:52
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

без вашей схемы данных подсказать что-то разумное не выйдет
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #4  
Старый 14.06.2013, 19:29
evgenia.ini evgenia.ini вне форума
Прохожий
 
Регистрация: 12.06.2013
Сообщения: 5
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

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

А можно сюда как-нибудь прогу поместить, чтобы Вы посмотрели, потому что я не знаю, как ещё объяснить

Последний раз редактировалось evgenia.ini, 14.06.2013 в 19:35.
Ответить с цитированием
  #5  
Старый 14.06.2013, 23:41
listerine listerine вне форума
Прохожий
 
Регистрация: 20.03.2013
Сообщения: 41
Версия Delphi: Delphi XE2
Репутация: выкл
По умолчанию

Предположим что у каждого рейса есть свой ID номер, можно фильтровать/искать по нему, далее уже отнимать 1 или соответственно прибавлять 1. Какая БД? Какие компоненты используешь?
Ответить с цитированием
  #6  
Старый 14.06.2013, 23:50
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Я в трамблёре (гугле) нашёл ссылок очень много на подобную задачу, даже с примерами, неужели нельзя было сделать тоже самое?
Ответить с цитированием
  #7  
Старый 15.06.2013, 11:58
evgenia.ini evgenia.ini вне форума
Прохожий
 
Регистрация: 12.06.2013
Сообщения: 5
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Использую DBGrid, DataSource, ADOConnection, ADOQuery
(фильтры у меня есть) можете подсказать сам текст программы?

Конечно, я пыталась найти в гугле, но как и в вашем случае, мне попадались только просто базы Asses с запросами. Как запросы использовать в Delphi я вообще не представляю
Ответить с цитированием
  #8  
Старый 15.06.2013, 12:30
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Начать надо с построения схемы данных. Я об этом писал еще в самом начале. После того как вы сделаете жизнеспособную схему, т.е. проверите добавление, удаление, выборки данных. Только после этого можно переходить к построению визуальной обертки над данными. Для построения схемы данных и проверки ее работоспособности я обычно использую MS Access. Вы можете поступить так же. Для начала сделайте схему и картинку сюда прикрепите.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #9  
Старый 15.06.2013, 20:19
listerine listerine вне форума
Прохожий
 
Регистрация: 20.03.2013
Сообщения: 41
Версия Delphi: Delphi XE2
Репутация: выкл
По умолчанию

Приведу простой пример чтоб смысл был понятен. Предположим на форме 1 расположена таблица со следующими столбцами: ID_Рейсаа, Откуда_Куда и Кол-во_билетов. Названия схематичны чтоб было понятно и столбцы самые необходимые. На 3 форме допустим таблица(пассажиры) со столбцами: ID_Рейса, ФИО_Пассажира.
Выбираем подходящий рейс и жмем (с ваших слов) кнопку "Купить билет", далее вводим ФИО пассажира и жмем ОК. И в таблицу(пассажиры) на 3 форме добавляется ФИО и ID рейса. Вот например можно так:
Код:
//ADOQuery1 - работает с таблицей на 1 форме
//ADOQuery3 - работает соответственно с таблицей на 3 форме 

//Вычитаем один билет если он есть
if ADOQuery1.FieldValues['Кол-во_билетов']<>0 then
begin
ADOQuery1.Edit;
ADOQuery1.FieldValues['Кол-во_билетов']:=ADOQuery1.FieldValues['Кол-во_билетов']-1;
ADOQuery1.Post;
end
else
begin
ShowMessage('Нет билетов');
exit;
end;
//Добавляем пассажира
ADOQuery3.Insert;
ADOQuery3.FieldValues['ID_Рейса']:=ADOQuery1.FieldValues['ID_Рейса'];
//Присваиваем  ID рейса пассажиру
ADOQuery3.FieldValues['ФИО_Пассажира']:=Edit1.Text;
//И фио, допустим оно в Едит1
ADOQuery3.Post;

А если надо удалить пассажира купившего билет. Можно сделать например так:

Код:
//Ищем нужный рейс
ADOQuery1.Filtred:=false;
ADOQuery1.Filter:=
'ID_Рейса = '+ADOQuery3.FieldValues['ID_Рейса'];
ADOQuery1.Filtred:=true;
//Поскольку Id рейса уникален он отфильтрует только 1 строчку
//На всякий случай проверку если не нашел
ADOQuery1.FieldValues['ID_Рейса']<>null then
begin
//И возвращаем билет
ADOQuery1.Edit;
ADOQuery1.FieldValues['Кол-во_билетов']:=
ADOQuery1.FieldValues['Кол-во_билетов']+1;
ADOQuery1.Post;
end
else
ShowMessage('Не найден рейс');

На всякий случай "FieldValues" обращение к выделенной строке.
Вариантов решение вашей задачи масса, раз ADOQuery тогда конечно лучше с помощью запросов, но можно и так. Я лишь привел код простой для понимания.
Ответить с цитированием
Этот пользователь сказал Спасибо listerine за это полезное сообщение:
evgenia.ini (17.06.2013)
  #10  
Старый 16.06.2013, 22:14
evgenia.ini evgenia.ini вне форума
Прохожий
 
Регистрация: 12.06.2013
Сообщения: 5
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Спасибо огромное, Вы написали то, что мне надо! Всё работает хорошо))

Последний раз редактировалось evgenia.ini, 16.06.2013 в 22:48.
Ответить с цитированием
  #11  
Старый 21.06.2013, 00:29
evgenia.ini evgenia.ini вне форума
Прохожий
 
Регистрация: 12.06.2013
Сообщения: 5
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

И всё-таки возникла одна проблема

получается, что в 1ой базе данных тип данных - счётчик, а во 2ой - числовой и при запуске фильтр

Код:
Form1.ADOQuery1.Filtered:=false;
Form1.ADOQuery1.Filter:='Код LIKE'+ #39 +Form2.ADOQuery1.FieldValues['Номер рейса']+ '%';

Form1.ADOQuery1.Filtered:=true;

выдаёт: Could not convert variant of type (String) into type (Double)

пробую перевести так:

Код:
var
 i: real;
begin
i:=StrToFloat(Form1.ADOQuery1.FieldByName('Код').Text);

ошибка
[Hint] Unit2.pas(82): Value assigned to 'i' never used

и всё та же надпись при запуске фильтра
Ответить с цитированием
  #12  
Старый 21.06.2013, 12:29
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

Цитата:
Сообщение от evgenia.ini
тип данных - счётчик, а во 2ой - числовой и при запуске фильтр
счетчик, надо полагать это автоинкремент? он тоже целочисленный

Цитата:
Сообщение от evgenia.ini
Код:
Form1.ADOQuery1.Filtered:=false;
Form1.ADOQuery1.Filter:='Код LIKE'+ #39 +Form2.ADOQuery1.FieldValues['Номер рейса']+ '%';

Form1.ADOQuery1.Filtered:=true;
кавычки открыли, а закрывать кто будет?

Цитата:
Сообщение от evgenia.ini
ошибка
[Hint] Unit2.pas(82): Value assigned to 'i' never used
Скопируйте в англо-русский словарь. Перевод о чем-нибудь говорит?
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #13  
Старый 21.06.2013, 16:23
listerine listerine вне форума
Прохожий
 
Регистрация: 20.03.2013
Сообщения: 41
Версия Delphi: Delphi XE2
Репутация: выкл
По умолчанию

Цитата:
Form1.ADOQuery1.Filtered:=false;
Form1.ADOQuery1.Filter:='Код LIKE'+ #39 +Form2.ADOQuery1.FieldValues['Номер рейса']+ '%';

Form1.ADOQuery1.Filtered:=true;

Вы точно смотрели что я писал?
Если вы фильтруете число то не каких LIKE, только = <> => <= и тд. Так же, не нужно #39, а если уж и ставите то надо закрывать и не стоит писать '%' из-за этого фильтр может быть не точным.

Цитата:
Could not convert variant of type (String) into type (Double)

это как раз из-за LIKE.

Цитата:
var
i: real;
begin
i:=StrToFloat(Form1.ADOQuery1.FieldByName('Код').T ext);

это код абсолютно не нужен.

придерживаясь всех эти правил и при условии что это
Цитата:
получается, что в 1ой базе данных тип данных - счётчик, а во 2ой - числовой и при запуске фильтр
так и есть работать будет без проблем. Будут вопросы, пишите в личку или на мыло объясню еще подробней.

И совет не используйте название столбцов с пробелами типа "Номер рейса" от греха подальше, заменяйте пробелы нижнем подчеркиванием например. А если оно мешает меняйте Caption столбца у Dbgrid.

Последний раз редактировалось listerine, 21.06.2013 в 16:29.
Ответить с цитированием
  #14  
Старый 22.06.2013, 01:51
listerine listerine вне форума
Прохожий
 
Регистрация: 20.03.2013
Сообщения: 41
Версия Delphi: Delphi XE2
Репутация: выкл
По умолчанию

evgenia.ini, ответил вам в личку.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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