русс | укр

Языки программирования

ПаскальСиАссемблерJavaMatlabPhpHtmlJavaScriptCSSC#DelphiТурбо Пролог

Компьютерные сетиСистемное программное обеспечениеИнформационные технологииПрограммирование

Все о программировании


Linux Unix Алгоритмические языки Аналоговые и гибридные вычислительные устройства Архитектура микроконтроллеров Введение в разработку распределенных информационных систем Введение в численные методы Дискретная математика Информационное обслуживание пользователей Информация и моделирование в управлении производством Компьютерная графика Математическое и компьютерное моделирование Моделирование Нейрокомпьютеры Проектирование программ диагностики компьютерных систем и сетей Проектирование системных программ Системы счисления Теория статистики Теория оптимизации Уроки AutoCAD 3D Уроки базы данных Access Уроки Orcad Цифровые автоматы Шпаргалки по компьютеру Шпаргалки по программированию Экспертные системы Элементы теории информации

Объединение запросов


Дата добавления: 2015-07-09; просмотров: 627; Нарушение авторских прав


 

Для объединения результатов двух и более запросов нужно использовать ключевое слово UNION. Объединяемые запросы должны иметь одинаковое количество и тип полей. Параметр ORDER BY , если он нужен, следует указывать только в последнемзапросе.

 

Получить список договоров и общую сумму счетов по каждому договору, а также строку с итоговой суммой:

 

SELECT CONCAT('Договор № ',

CONVERT(k_contract_contract_num, CHAR),

' на сумму ') AS "Номер",

SUM(bill_sum) AS "Сумма" FROM k_bill

GROUP BY k_contract_contract_num

UNION

SELECT 'ИТОГО: ', SUM(bill_sum) FROM k_bill ORDER BY 1

 

И еще несколько примеров

Получить прайс-лист с суммой заказов по каждому товару. Обратите внимание, что название и цена товара могут использоваться в списке полей для выбора, поскольку они функционально зависят от номера товара, по которому проводится группировка.

 

SELECT pr.price_name, pr.price_sum,

SUM(prot.kolvo*prot.price_sum)

FROM k_price pr, k_protokol prot

WHERE pr.price_num=prot.k_price_price_num

GROUP BY pr.price_num ORDER BY 1

 

 

Полностью оплаченные счета, т.е., счета, сумма платежей по которым больше или равна сумме счета. Обратите внимание на применение подзапроса.

SELECT b.bill_num AS "Номер счета",



b.bill_date AS "Дата счета",

b.bill_sum AS "Сумма счета",

SUM(p.payment_sum) AS "Сумма оплаты"

FROM k_bill b, k_payment p

WHERE b.bill_num=p.k_bill_bill_num AND

b.bill_sum<=

(SELECT SUM(payment_sum) FROM k_payment p2

WHERE b.bill_num=p2.k_bill_bill_num)

GROUP BY b.bill_num

 

Полностью неоплаченные счета, по которым вообще нет платежей.

SELECT b.bill_num AS "Номер счета",



b.bill_date AS "Дата счета",

b.bill_sum AS "Сумма счета",

0 AS "Сумма оплаты"

FROM k_bill b

WHERE b.bill_num NOT IN (SELECT k_bill_bill_num FROM k_payment)

Частично оплаченные счета. Обратите внимание, что в этом примере в параметре FROM вместо второй таблицы используется вложенный SELECT

SELECT b.bill_num AS "Номер счета",



b.bill_date AS "Дата счета",

b.bill_sum AS "Сумма счета",

p.pay_sum AS "Сумма оплаты"

FROM k_bill b,

(SELECT k_bill_bill_num, SUM(payment_sum) as pay_sum

FROM k_payment

GROUP BY k_bill_bill_num) p

WHERE b.bill_sum >p.pay_sum AND b.bill_num=p.k_bill_bill_num

 

Задание. Напишите несколько (не менее 10) интересных запросов к вашей базе данных. Используйте вложенные подзапросы, группировки, итоговые значения, выборки из нескольких таблиц. Если ваш запрос требует ввода параметра, замените его пока на константу, запросы с параметрами можно будет в дальнейшем реализовать с помощью хранимых процедур.

 

Дополнительная информация. Подробнее о команде SELECT, используемых в ней операциях и функциях можно прочитать в [1, Глава 2, параграф 2.5, Глава 3], [3, Главы 5,6,7].

 



<== предыдущая лекция | следующая лекция ==>
Выборка из нескольких таблиц | НАБІР WEB-розробника DENWER


Карта сайта Карта сайта укр


Уроки php mysql Программирование

Онлайн система счисления Калькулятор онлайн обычный Инженерный калькулятор онлайн Замена русских букв на английские для вебмастеров Замена русских букв на английские

Аппаратное и программное обеспечение Графика и компьютерная сфера Интегрированная геоинформационная система Интернет Компьютер Комплектующие компьютера Лекции Методы и средства измерений неэлектрических величин Обслуживание компьютерных и периферийных устройств Операционные системы Параллельное программирование Проектирование электронных средств Периферийные устройства Полезные ресурсы для программистов Программы для программистов Статьи для программистов Cтруктура и организация данных


 


Не нашли то, что искали? Google вам в помощь!

 
 

© life-prog.ru При использовании материалов прямая ссылка на сайт обязательна.

Генерация страницы за: 0.132 сек.