|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
Qreport типа master-detail (table+query)31.03.2012, 17:31. Показов 2388. Ответов 6
Метки нет (Все метки)
Собственно, лабораторные делаются по учебной базе "Борей", которая идет с аксессом.
Нужен отчет типа: Товар Марка -Код заказа Название Количество Цена С master все просто - настроить на табличку "Товары" и дело в шляпе. Проблема возникает после создания запроса - выводить у меня все выводит, но как сделать так, чтобы Таблица и Запрос связывались по полю "КодТовара" (в запросе присутствует), а то у меня на каждый из товаров выводит полный результат работы запроса. Для наглядности добавил часть, которую отвечает за отчет в отдельный проект (прикреплен), хоть и кривовато. Буду благодарен за подсказки. temp.rar
0
|
|
| 31.03.2012, 17:31 | |
|
Ответы с готовыми решениями:
6
Master-Detail FireBird в С++ InterBase, BDE, Master-Detail Связка двух SQL запросов Master Detail |
|
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
|
|
| 31.03.2012, 22:07 | |
|
Запрос связывались по полю "КодТовара" (в запросе присутствует), а то у меня на каждый из товаров выводит полный результат работы запроса.
Очевидно я не совсем понял ваш вопрос, "связаться по полю КодТовара". Если вам нужно вывести конкретные значения например, то почему бы вам не использовать проверки типа where(" ") или установить связь при помощи компонентов в DataSourse и от туда делать связь, а потом делать запрос ?
0
|
|
|
анимешник++
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
|
|
|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
| 31.03.2012, 22:36 [ТС] | |
|
Ах да, на случай, если нету Борея у кого. Ложить в корень С:\
DSN внутри, но это не важно.
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
|
|
|
анимешник++
95 / 62 / 7
Регистрация: 03.11.2009
Сообщений: 427
|
|
| 01.04.2012, 12:34 [ТС] | |
|
Nikolay88_X, похоже, Вы меня все-таки не поняли =(
Не в самом запросе дело, и даже то, что он не по порядку ничего не меняет. Мне нужно, чтобы в самом отчете в качестве Detail заголовка были товары, а в качестве SubDetail все заказы по данному товару. Попробую привести пример в качестве исходника для двух таблиц "Клиенты - заказы". Вот, что я получил: Для 2й таблицы есть свойство Master и выбор поля, по которому она связывается с родительской. Для Query такого поля я не нашел, а выполнять много раз 1 запрос с разными параметрами, чтобы получить данные для отчета конечно можно, но можно ли их потом будет в 1 отчет склеить?
0
|
|
|
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
|
|
| 01.04.2012, 15:41 | |
|
чтобы связать запрос по полю из таблицы для Table1 нужно сделать примерно такое
Для Query будет так select *from Товары where(Товары=:заказы); заказы - это параметр из другой таблице затем если Query у вас вспомогательная таблица то настройте ее Datasourse на Datasourse1 и тогда вы их свяжите....
0
|
|
| 01.04.2012, 15:41 | |
|
Помогаю со студенческими работами здесь
7
Организация заголовков в qreport detail
Master-detail JqGrid master detail Master Detail Flow Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
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 .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|