Читаем SQL: быстрое погружение полностью

Используя условие ORDER BY, мы можем упорядочить результаты по полю, где отображается каждая категория покупки в алфавитном порядке, начиная с Baseline Purchase (базовая покупка) и заканчивая Top Performer (значительная покупка). Для ясности мы присвоили каждой категории свои имена, но вы можете присвоить им любое другое имя.

Теперь, когда новые категории созданы, нам необходимо узнать больше о демографических характеристиках наших клиентов на основе наших новых категорий продаж. Существует множество способов структурировать остальную часть оператора SELECT.

Ответим на следующие вопросы.

• В каких городах осуществляются самые эффективные продажи?

• Самые эффективные продажи в основном осуществляются в США или в других странах?

• В каких городах совершается больше всего базовых покупок?

Рассмотрим первый вопрос. Чтобы получить данные только об эффективных продажах и упорядочить их по городам, мы можем изменить наш существующий запрос, используя условие WHERE.

SELECT

InvoiceDate,

BillingAddress,

BillingCity,

Total,

CASE

WHEN TOTAL < 2.00 THEN 'Baseline Purchase'

WHEN TOTAL BETWEEN 2.00 AND 6.99 THEN 'Low

Purchase'

WHEN TOTAL BETWEEN 7.00 AND 15.00 THEN 'Target

Purchase'

ELSE 'Top Performers'

END AS PurchaseType

FROM

invoices

WHERE PurchaseType = 'Top Performers'

ORDER BY

BillingCity

Рис. 61

Проанализировав результат запроса, мы можем определить, что самые эффективные продажи в основном осуществляются в США.

Комбинации полей, по которым проводится поиск, практически безграничны. Например, мы можем получить данные в зависимости от даты выставления счета, чтобы проанализировать сезонные продажи. Использование операторов CASE с условием WHERE и операторами, изученными в этой главе, поможет получить данные, необходимые для нашего отдела продаж.

Примечание

В примерах в этой главе мы использовали оператор CASE в части запроса SELECT после необходимых для отображения полей. Далее вы можете встретить запрос, в котором оператор CASE содержится в условии WHERE (редкий случай). Все, что сейчас важно, — это помнить, что оператор CASE должен быть указан в условии SELECT, но ссылаться на него можно из другого места программного кода.

<p id="_8_xhtml_2523toc_marker_8_11"><strong>Контрольные вопросы</strong></p>

1. Создайте запрос для таблицы invoices, включающий оператор CASE, который будет отмечать все продажи из США — страны, откуда выставлен счет — как Domestic Sales (Продажи на внутреннем рынке), а все другие продажи — как Foreign Sales (Продажи за рубежом). После оператора ENDAS создайте новое поле SalesType.

2. Отсортируйте эти данные по новому полю SalesType.

3. Сколько счетов от продаж на внутреннем рынке превышает сумму $15?

<p id="_8_xhtml_2523toc_marker_8_12"><strong>Резюме</strong></p>

• Операторы — это специальные ключевые слова SQL, которые используются с условиями SQL для фильтрации данных в зависимости от определенных условий.

• Использование условия WHERE с комбинацией различных операторов позволяет выполнять поиск определенного текста, даты и числа.

• Функция DATE() позволяет исключить время при указании параметров даты.

• Порядок операций при использовании логических операторов (таких как AND/OR) устанавливается с помощью круглых скобок ().

• Оператор CASE позволяет отмечать записи специальным именем поля в зависимости от заданных пользователем логических условий.

*** Существует некая путаница в терминологии. В английском языке есть два разных слова, statement и operator, которые чаще всего переводят одинаково — оператор. Встречается также перевод слова operator (в применении к арифметическим, логическим и сравнения) как «операция», а перевод слова statement как «инструкция». Мы будем использовать термин «оператор» как наиболее привычный. — Примеч. ред.

<p id="_9_xhtml_2523toc_marker_9"><strong>Глава 6. Работа с несколькими таблицами</strong></p>

Во всех предыдущих запросах мы рассматривали получение данных только из одной таблицы. Хотя мы изучили некоторые мощные запросы, они не используют все возможности реляционной базы данных. База данных sTunes содержит тринадцать таблиц. Каждая таблица содержит некоторую, но не всю, информацию о компании. Чтобы ответить на более сложные вопросы о компании sTunes, понадобится одновременный доступ к данным из нескольких таблиц. В этой главе мы узнаем, как получить данные из двух или более таблиц с помощью одного запроса и инструментов, называемых соединениями.

<p id="_9_xhtml_2523toc_marker_9_1"><strong>Что такое соединение</strong></p>

Соединение (join) — это операция, которая объединяет поля двух или более таблиц реляционной базы данных. Рассмотрим очень простой пример использования таблицы invoices в базе данных sTunes. В предыдущих главах мы много работали с таблицей invoices, поэтому она хорошо нам знакома. На вкладке Browse Data (Просмотр данных) браузера SQL (рис. 62) видно, что таблица invoices состоит из девяти полей. Поле InvoiceId содержит идентификационный номер каждого счета. Поле CustomerId — идентификационный номер каждого клиента (которому выставлен счет). Таблица invoices также содержит поля с информацией о дате и сумме счета. Остальные поля в этой таблице предназначены для адреса плательщика.

Рис. 62

Перейти на страницу:

Все книги серии Библиотека программиста

Программист-фанатик
Программист-фанатик

В этой книге вы не найдете описания конкретных технологий, алгоритмов и языков программирования — ценность ее не в этом. Она представляет собой сборник практических советов и рекомендаций, касающихся ситуаций, с которыми порой сталкивается любой разработчик: отсутствие мотивации, выбор приоритетов, психология программирования, отношения с руководством и коллегами и многие другие. Подобные знания обычно приходят лишь в результате многолетнего опыта реальной работы. По большому счету перед вами — ярко и увлекательно написанное руководство, которое поможет быстро сделать карьеру в индустрии разработки ПО любому, кто поставил себе такую цель. Конечно, опытные программисты могут найти некоторые идеи автора достаточно очевидными, но и для таких найдутся темы, которые позволят пересмотреть устоявшиеся взгляды и выйти на новый уровень мастерства. Для тех же, кто только в самом начале своего пути как разработчика, чтение данной книги, несомненно, откроет широчайшие перспективы. Издательство выражает благодарность Шувалову А. В. и Курышеву А. И. за помощь в работе над книгой.

Чед Фаулер

Программирование, программы, базы данных / Программирование / Книги по IT

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных