Форум программистов, компьютерный форум, киберфорум
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. Показов 2388. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru