- •Вводный раздел
- •1. Информационные системы. Основные понятия
- •Моделирование информационных систем
- •2. Архитектуры распределенного приложения с базой данных. Функции клиента и сервера при различных вариантах расслоения. Типовые клиенты доступа к бд на основе различных технологий.
- •Модель Клиент – Сервер
- •Трехуровневая модель
- •Распределенная (многоуровневая) модель
- •4 Технологии программ расширений
- •Тема 1. Средства взаимодействия клиента и сервера бд
- •1.1 Сервисы сети Internet. Сетевая архитектура osi.
- •1.2 Протоколы прикладного уровня в стеке tcp/ip. Унифицированный локатор ресурса при работе с бд
- •1.3 Блоки данных в стеке протоколов
- •Тема 2. Удаленные базы данных
- •2.1 Понятие удаленных баз данных
- •2.2 Инструментальные средства проектирования структуры бд. Утилиты автоматизированного проектирования бд.
- •2.3 Характеристика субд удаленного доступа
- •Тема 3. Разработка и эксплуатация серверной части
- •3.1 Проектирование структуры базы данных (на самостоятельное изучение) Вопросы для самостоятельной работы
- •3.2 Создание баз данных, таблиц и индексов
- •Удаление баз данных, таблиц
- •Изменение структуры таблиц
- •3.3 Типы данных в MySql
- •Integer и его вариации
- •3.4 Методы заполнения полей базы данных Использование insert
- •Использование replace
- •Использование delete
- •Использование truncate
- •Использование update
- •Загрузка данных с помощью load data infile
- •Тема 4. Разработка и эксплуатация клиентской части.
- •4.1 Простые запросы
- •4.2 Выбор строк с помощью where
- •Удаление повторений с помощью distinct
- •Выбор групп с помощью having
- •Сортировка результатов поиска с помощью order by
- •Ограничение результатов поиска с помощью limit
- •4.4 Сложные запросы Объединение двух таблиц
- •Объединение нескольких таблиц
- •Самообъединение таблиц
- •Типы объединений
- •4.5 Создание подзапросов
- •4.6 Встроенные функции MySql
- •Операторы
- •Типы таблиц MySql
- •Тема 5. Язык html как средство внешнего представления данных.
- •5.1 Основные правила проектирования пользовательского интерфейса
- •5.2. Построение абзацев в гипертекстовом документе
- •5.3 Построение заголовков в гипертекстовом документе
- •Тема 6. Разработка бизнес-слоя и интерактивных компонентов
- •6.1 Perl как средство разработки программ –приложения
- •6.2 Типы данных в Рerl
- •Переменные
- •Скалярные переменные
- •Массивы
- •Ассоциативные массивы
- •6.3 Конструкции языка Рerl Простые и составные операторы
- •Условные операторы
- •Оператор unless
- •Оператор do
- •Циклы и ветвления
- •Цикл until
- •Циклы for и foreach
- •Оператор безусловного перехода goto
- •Генерация динамических выражений с помощью функции eval
- •6.4 Подпрограммы
- •Использование пакетов для изоляции подпрограмм
- •6.5 Операторы языка Perl .Операторы сравнения
- •Логические операторы
- •6.6 Работа с файлами и строками
- •Функция chop
- •Функция index
- •Функция length
- •Функция substr
- •Функция join
- •Функция split
- •Функции для обработки списков
- •Функция reverse
- •Функция sort
- •Функции работы с массивами
- •Функции push и pop
- •Функция shift
- •Функция unshift
- •Функция splice
- •Функция scalar
- •Функция grep
- •Функции обработки ассоциативных массивов
- •Функция keys
- •Функция values
- •Функция each
- •Функция delete
- •Пример скриптов для выполнения практического задания
- •1. Добавление информации в базу (на примере винного погреба -добавление страны)
- •Часть 1
- •Удаление информации из базы (удаление страны)
- •Часть 2
- •Часть 3
- •Поиск информации в базе данных
- •Занесение новой информации во все таблицы базы данных
- •Часть 1
- •Часть 2
Типы объединений
Существуют различные типы объединений, варианты которых могут использоваться в MySQL.
Основное объединение
В предыдущей теме мы упомянули понятие декартова произведения. В данном контексте его иногда называют полным или перекрестным объединением, но, независимо от терминологии, такое объединение возвращает полный набор комбинаций. При добавлении к объединению некоторого условного выражения (типа employee. departmentID = department. departmentID) мы превращаем его в нечто, называемое объединением по эквивалентности, которое ограничивает число возвращаемых запросом строк.
До сих пор мы использовали набор таблиц, перечисленных в выражении FROM и разделенных запятыми. Это определяло, как было показано выше, перекрестное объединение, которое превращалось в объединение по эквивалентности с помощью выражения WHERE. MySQL предлагает различные формы синтаксиса для объединений такого типа.
Рассмотрим наш оригинальный запрос:
select employee.name, department.name
from employee, department
where employee.departmentID = department.departmentID;
Вместо запятой в выражении FROM можно использовать ключевое слово JOIN:
select employee.name, department.name
from employee join department
where employee.departmentID = department.departmentID;
Вместо JOIN точно так же можно использовать CROSS JOIN (перекрестное объединение) или INNER JOIN (внутреннее объединение).
При использовании этого типа объединения MySQL находит связываемые таблицы и пытается объединить их оптимальным образом, не обязательно в том порядке, в котором их перечислите вы. Если вы хотите отменить оптимизацию и заставить MySQL связать таблицы в указанном вами порядке, замените слово JOIN выражением STRAIGHT JOIN (непосредственное объединение).
Левые и правые объединения
Рассмотрим, например, ситуацию, когда требуется выяснить имена служащих, еще не получавших внешних заданий, т.е. служащих, коды которых (emp1оуееID) отсутствуют в таблице (assignment). Решить такую задачу можно с помощью LEFT JOIN, как показано ниже.
select employee.name
from employee left join assignment
on employee.employeelD = assignment.employeelD
where clientID is null;
Давайте снова вернемся к нашему примеру. В указанном объединении для каждого служащего, имеющего задание, мы получим строку с информацией о служащем и задании. Если служащий не имеет соответствующей строки в таблице заданий, левое объединение добавит "фиктивную строку", состоящую из одних значений NULL. Такие фиктивные строки можно найти с помощью поиска служащих, для которых полученные задания имеют значение NULL в поле clientID. (Поле clientID является ключевым полем, поэтому в самой таблице assignment такое просто невозможно.)
В данном примере мы использовали LEFT JOIN, но точно так же можно использовать RIGHT JOIN, которое работает аналогично, но использует в качестве основной правую таблицу, а вместо отсутствующих строк левой таблицы создает строки значений NULL.
