- •Основные понятия
- •1.1.Состав субд
- •1.2. Классификация баз данных
- •1. 3. Архитектура баз данных
- •Глава 2 проектирование баз данных
- •2.1. Этапы проектирования базы данных
- •2.2. Моделирование локальных представлений
- •3.1 Иерархические модели
- •3.2. Сетевые модели
- •3.3. Реляционные базы данных
- •Реляционные основы концептуального проектирования
- •4.1. Нормализация отношений
- •4.2. Проектирование реляционных баз данных (рбд)
- •5. Агрегированные объекты могут быть сведены в одно реляционное отношение в том случае, если те объекты, с которыми связан каждый из них, полностью совпадают (рис.4.13).
- •Упражнения к главе 4
- •Операции над отношениями
- •5.1. Выполнение операций над отношениями
- •На рис.5.1 приведены примеры операций реляционной алгебры над отноше
- •Реляционные языки запросов
- •6.1. Язык sql (Structured Query Language)
- •6.2. Операторы манипулирования данными
- •Поставщики (s)Tаблица 6.1
- •6.3.Выборки
- •Результат: номер поставщикасостояние
- •Результат: номер_деталивес
- •Р6 Шайба Красный 19 Липецк
- •6.4.3Апросы, использующие соединения
- •6.5.Подзапросы
- •6.6. Подзапросы с несколькими уровнями вложения
- •6.7. Коррелированный подзапрос.
- •6.8. Квантор существования. Запрос, использующий exists
- •6.9. Стандартные функции
- •6.10. Использование группировок (group by)
- •6.11. Объединение с использованием union
- •6.12. Многоаспектный запрос
- •6.13. Операции обновления
- •6.14. Представления
- •Упражнения к главе 6
- •Субд foxpro 2.0
- •7.1. Системный интерфейс FoxPro, главное меню
- •7.2. Архитектура субд FoxPro 2.0
- •Типы и размеры полей (в байтах).
- •Поле дат 8.
- •7.3. Основные команды FoxPro 2.0
- •7.4. Создание и редактирование бд
- •Антонов 4
- •7.5. Команды просмотра и редактирования записей
- •7.6. Создание командных файлов
- •Сведения о сотрудниках
- •7.7. Команды управления
- •7.8. Циклы в FoxPro
- •7.9. Построение экранных форм
- •Карта ввода
- •Карта ввода
- •7.10. Работа с массивами
- •Фио Должность Оклад
- •7.11. Построение меню
- •Пример составления меню
- •7.12. Модульное программирование
- •7.13.Изобразительные средства субд
- •7.14. Функции в FoxPro
- •7.15. Работа с несколькими бд, связывание бд
- •7.16. Работа с окнами
- •Упражнения к главе 7
- •Создание базы данных в среде Microsoft Access
- •8.1. Создание и открытие базы данных
- •8.2. Конструирование форм в среде Microsoft Access
- •8.3. Связывание таблиц в Microsoft Access
- •8.4. Запросы к связанным таблицам
- •8.5. Отчеты
- •8.6. Рисунки и другие объекты в среде Microsoft Access
- •Приложение 1 База данных поставок
- •Приложение 2 Список вопросов для повторения учебного материала
- •Приложение 3 Задания для самостоятельного выполнения
- •Список литературы
- •Оглавление
- •Глава 7. Субд foxpro 2.0................................................…….........………… 54
- •Глава 8. Создание базы данных в среде Microsoft Access .........……................88
6.3.Выборки
Основной операцией в языке SQL является отображение, синтаксически представляющее собой блок SELECT – FROM - WHERE (выбрать – из – где).
38
Структура оператора SELECT:
SELECT [DISTINCT] элементы
FROM таблица
[WHERE предикат]
[GROUP BY поле [HAVING [предикат]]
[ORDER BY поле]
Пример 6.2. Выдать номера и состояния для поставщиков, находящихся в Перми:
SELECT НОМЕР_ПОСТАВЩИКА, СОСТОЯНИЕ
FROM S
WHERE ГОРОД= 'Пермь'
Результат: НОМЕР ПОСТАВЩИКА СОСТОЯНИЕ
S2 10
S3 30
Пример 6.3. Простая выборка. Выдать номера для всех поставляемых деталей:
SELECT НОМЕР_ДЕТАЛИ
FROM SP
Результат: НОМЕР ДЕТАЛИ
Р1
Р2
РЗ
Р4
Р5
Р6
Р1
Р2
Р2
P4
Р5
Пример 6.4. Выборка с исключением дубликатов.
SELECT DISTINCT НОМЕР_ДЕТАЛИ
FROM SP
Результат: НОМЕР ДЕТАЛИ
Р1
Р2
РЗ
Р4
Р5
Р6
SELECT DISTINCT - выбрать различные.
Пример 6.5. Выборка вычисляемых значений. Выдать номер и вес каждой детали:
SELECT НОМЕР_ДЕТАЛИ, ВЕС
FROM P
39
Результат: НОМЕР ДЕТАЛИ ВЕС
Р1 12
Р2 17
РЗ 17
Р4 14
Р5 12
Рб 19
Пример 6.6. Фраза SELECT (и фраза WHERE) может включать арифметические выражения, а также прочие имена полей. Можно, кроме того, осуществлять выборку просто констант.
SELECT НОМЕР_ДЕТАЛИ, 'Вес в граммах=', ВЕС
FROM P
Результат: НОМЕР ДЕТАЛИ ВЕС
. Р1 Вес в граммах= 12
Р2 Вес в граммах= 17
РЗ Вес в граммах= 17
Р4 . Вес в граммах= 14
Р5 Вес в граммах= 12
Р6 Вес в граммах= 19
Пример 6.7. Выдать полные характеристики для всех поставщиков:
SELECT *
FROM S
Результатом будет таблица S со всеми полями.
Пример 6.8. Ограниченная выборка. Выдать номера поставщиков, которые находятся в Перми и имеют состояние больше, чем 20.
SELECT НОМЕР_ПОСТАВЩИКА
FROM S
WHERE ГОРОД=’Пермь’ AND СОСТОЯНИЕ > 20
Результат: НОМЕР ПОСТАВЩИКА
S3
Условие или предикат, следующий за ключевым словом WHERE, может включать операторы сравнения =, = (не равно), >, >, >=, , < и <=, булевские операторы AND (и), OR (или) и NOT (нет), а скобки указывают требуемый порядок вычислений.
Пример 6.9. Выборка с упорядочением. Выдать номера и состояния поставщиков, находящихся в Перми, в порядке убывания их состояния:
SELECT НОМЕР_ПОСТАВЩИКА
FROM S
WHERE ГОРОД=’Пермь’
ORDER BY СОСТОЯНИЕ DESC
40