Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
анимешник++
 Аватар для Iworb
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427

Qreport типа master-detail (table+query)

31.03.2012, 17:31. Показов 2488. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Собственно, лабораторные делаются по учебной базе "Борей", которая идет с аксессом.
Нужен отчет типа:
Товар Марка
-Код заказа Название Количество Цена

С master все просто - настроить на табличку "Товары" и дело в шляпе.
Проблема возникает после создания запроса - выводить у меня все выводит, но как сделать так, чтобы Таблица и Запрос связывались по полю "КодТовара" (в запросе присутствует), а то у меня на каждый из товаров выводит полный результат работы запроса.

Для наглядности добавил часть, которую отвечает за отчет в отдельный проект (прикреплен), хоть и кривовато.
Буду благодарен за подсказки.
temp.rar
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
31.03.2012, 17:31
Ответы с готовыми решениями:

Master-Detail FireBird в С++
Всем привет! помогите выручайте! работаю на с++ с firebird-ом через стандартные компоненты с++, то есть через компонент ibdatabase, ibquery...

InterBase, BDE, Master-Detail
Здравствуйте. Нужно задать связь Master-Detail программно. Пишу такой код:void __fastcall TForm1::Button1Click(TObject *Sender) { ...

Связка двух SQL запросов Master Detail
Добрый день. Точнее, доброго времени суток ;) Для работы с базой MSSQL использую компоненты ADO. Вопрос заключается в следующем, как...

6
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
31.03.2012, 22:07
Запрос связывались по полю "КодТовара" (в запросе присутствует), а то у меня на каждый из товаров выводит полный результат работы запроса.
Очевидно я не совсем понял ваш вопрос, "связаться по полю КодТовара". Если вам нужно вывести
конкретные значения например, то почему бы вам не использовать проверки типа where(" ")
или установить связь при помощи компонентов в DataSourse и от туда делать связь, а потом делать запрос ?
0
анимешник++
 Аватар для Iworb
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
31.03.2012, 22:34  [ТС]
Nikolay88_X,
Мне нужно, чтобы выводился весь список товаров и по каждому из них список заказов с указанием имен клиентов.
Это можно сделать и в 1 запрос, но мне нужен отчет именно master-detail
Попробую привести пример:
КодТовара1 Марка1
-КодТовара1 КодЗаказа1 Название1 Цена1
-КодТовара1 КодЗаказа2 Название2 Цена2
-КодТовара1 КодЗаказа3 Название3 Цена3
КодТовара2 Марка2
-КодТовара2 КодЗаказа4 Название4 Цена4
-КодТовара2 КодЗаказа5 Название5 Цена5
КодТовара3 Марка3
-КодТовара3 КодЗаказа6 Название6 Цена6
-КодТовара3 КодЗаказа7 Название7 Цена7
(Естественно, на отчете КодТовара в detail запросе не отображается, это просто так, для примера)

Так вот, в отчете в качестве master выступает таблица "Товары", а в качестве detail выступает запрос, в котором ВСЕ значения этого запроса.

Добавлено через 1 минуту
P.S. У меня же получается такое:
КодТовара1 Марка1
-КодТовара1 КодЗаказа1 Название1 Цена1
-КодТовара1 КодЗаказа2 Название2 Цена2
-КодТовара1 КодЗаказа3 Название3 Цена3
-КодТовара2 КодЗаказа4 Название4 Цена4
-КодТовара2 КодЗаказа5 Название5 Цена5
-КодТовара3 КодЗаказа6 Название6 Цена6
-КодТовара3 КодЗаказа7 Название7 Цена7
КодТовара2 Марка2
-КодТовара1 КодЗаказа1 Название1 Цена1
-КодТовара1 КодЗаказа2 Название2 Цена2
-КодТовара1 КодЗаказа3 Название3 Цена3
-КодТовара2 КодЗаказа4 Название4 Цена4
-КодТовара2 КодЗаказа5 Название5 Цена5
-КодТовара3 КодЗаказа6 Название6 Цена6
-КодТовара3 КодЗаказа7 Название7 Цена7
КодТовара3 Марка3
-КодТовара1 КодЗаказа1 Название1 Цена1
-КодТовара1 КодЗаказа2 Название2 Цена2
-КодТовара1 КодЗаказа3 Название3 Цена3
-КодТовара2 КодЗаказа4 Название4 Цена4
-КодТовара2 КодЗаказа5 Название5 Цена5
-КодТовара3 КодЗаказа6 Название6 Цена6
-КодТовара3 КодЗаказа7 Название7 Цена7
0
анимешник++
 Аватар для Iworb
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
31.03.2012, 22:36  [ТС]
Ах да, на случай, если нету Борея у кого. Ложить в корень С:\
DSN внутри, но это не важно.
Вложения
Тип файла: rar Борей.rar (316.1 Кб, 16 просмотров)
0
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
01.04.2012, 11:53
Ваш запрос состоял из:

SELECT Заказано.КодТовара, Заказано.КодЗаказа, Заказано.Цена, Заказано.Количество, Клиенты.Название
FROM Клиенты INNER JOIN (Заказы INNER JOIN Заказано ON Заказы.КодЗаказа = Заказано.КодЗаказа) ON Клиенты.КодКлиента = Заказы.КодКлиента;

Пример:

SELECT Заказы.КодКлиента, Товары.Марка, Sum(CCur(Заказано!Цена*Заказано!Количест во*(1-Заказано!Скидка))) AS Выручка, Sum(CCur((Заказано!Цена*Заказано!Количес тво*(1-Заказано!Скидка))-(Товары!Цена-Заказано!Количество))) AS Маржа, Заказы.ДатаРазмещения
FROM (Типы INNER JOIN (Поставщики INNER JOIN Товары ON Поставщики.КодПоставщика=Товары.КодПоста вщика) ON Типы.КодТипа=Товары.КодТипа) INNER JOIN (Заказы INNER JOIN Заказано ON Заказы.КодЗаказа=Заказано.КодЗаказа) ON Товары.КодТовара=Заказано.КодТовара
WHERE Типы.Категория="Напитки" And Заказы.ДатаРазмещения Between #1/1/1996# And #1/1/2000#

GROUP BY Заказы.СтранаПолучателя, Заказы.КодКлиента, Товары.Марка, Заказы.ДатаРазмещения

Having Товары.Марка & "|" & Заказы.КодКлиента not in (SELECT Товары.Марка & "|" & Клиенты.КодКлиента FROM Клиенты INNER JOIN (Заказы INNER JOIN ((Типы INNER JOIN (Поставщики INNER JOIN Товары ON Поставщики.КодПоставщика = Товары.КодПоставщика) ON Типы.КодТипа = Товары.КодТипа) INNER JOIN Заказано ON Товары.КодТовара = Заказано.КодТовара) ON Заказы.КодЗаказа = Заказано.КодЗаказа) ON Клиенты.КодКлиента = Заказы.КодКлиента
WHERE Типы.Категория="Напитки" AND Заказы.ДатаРазмещения Between #1/1/1998# And #3/31/1998# GROUP BY Товары.Марка & "|" & Клиенты.КодКлиента)


Отсюда следует что вы не выполняли проверки на наличие совместимости, и поэтому у вас
Не по порядку выводит. И получается
-КодТовара1 КодЗаказа1 Название1 Цена1
-КодТовара1 КодЗаказа2 Название2 Цена2
-КодТовара1 КодЗаказа3 Название3 Цена3
-КодТовара2 КодЗаказа4 Название4 Цена4
-КодТовара2 КодЗаказа5 Название5 Цена5
-КодТовара3 КодЗаказа6 Название6 Цена6
-КодТовара3 КодЗаказа7 Название7 Цена7
0
анимешник++
 Аватар для Iworb
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
01.04.2012, 12:34  [ТС]
Nikolay88_X, похоже, Вы меня все-таки не поняли =(
Не в самом запросе дело, и даже то, что он не по порядку ничего не меняет.
Мне нужно, чтобы в самом отчете в качестве Detail заголовка были товары, а в качестве SubDetail все заказы по данному товару. Попробую привести пример в качестве исходника для двух таблиц "Клиенты - заказы".
Вот, что я получил:
Для 2й таблицы есть свойство Master и выбор поля, по которому она связывается с родительской. Для Query такого поля я не нашел, а выполнять много раз 1 запрос с разными параметрами, чтобы получить данные для отчета конечно можно, но можно ли их потом будет в 1 отчет склеить?
Вложения
Тип файла: rar temp.rar (5.7 Кб, 32 просмотров)
0
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
01.04.2012, 15:41
чтобы связать запрос по полю из таблицы для Table1 нужно сделать примерно такое
Для Query будет так

select *from Товары where(Товары=:заказы);

заказы - это параметр из другой таблице

затем если Query у вас вспомогательная таблица то настройте ее Datasourse на Datasourse1
и тогда вы их свяжите....
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.04.2012, 15:41
Помогаю со студенческими работами здесь

Организация заголовков в qreport detail
есть 2 таблицы 1ая таблица 2ая таблица ааа ддд ббб ...

Запись данных в таблицу с другого сервера (Что-то типа Select * into table from exec ('query')
Всем привет! Нужно записать в таблицу данные с другого сервака. Данные могу получить только с помощью exec (' select * from t')....

Master-detail
Здравствуйте. Подскажите пожалуйста каким образом можно удалить запись из мастера в приложении master-detail? Задача - по нажатию кнопки...

JqGrid master detail
Доброе время суток. Прошу сильно не пинать, либо пнуть в нужном направлении. Пытаюсь разобраться с jqGrid...

Master Detail Flow
package com.example.bp.dummy; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru