🗊Презентация Запросы с групповыми операциями

Категория: Информатика
Нажмите для полного просмотра!
Запросы с групповыми операциями, слайд №1Запросы с групповыми операциями, слайд №2Запросы с групповыми операциями, слайд №3Запросы с групповыми операциями, слайд №4Запросы с групповыми операциями, слайд №5Запросы с групповыми операциями, слайд №6Запросы с групповыми операциями, слайд №7Запросы с групповыми операциями, слайд №8Запросы с групповыми операциями, слайд №9Запросы с групповыми операциями, слайд №10Запросы с групповыми операциями, слайд №11Запросы с групповыми операциями, слайд №12Запросы с групповыми операциями, слайд №13Запросы с групповыми операциями, слайд №14Запросы с групповыми операциями, слайд №15Запросы с групповыми операциями, слайд №16Запросы с групповыми операциями, слайд №17Запросы с групповыми операциями, слайд №18Запросы с групповыми операциями, слайд №19Запросы с групповыми операциями, слайд №20Запросы с групповыми операциями, слайд №21

Вы можете ознакомиться и скачать презентацию на тему Запросы с групповыми операциями. Доклад-сообщение содержит 21 слайдов. Презентации для любого класса можно скачать бесплатно. Если материал и наш сайт презентаций Mypresentation Вам понравились – поделитесь им с друзьями с помощью социальных кнопок и добавьте в закладки в своем браузере.

Слайды и текст этой презентации


Слайд 1





Запросы с групповыми операциями
Описание слайда:
Запросы с групповыми операциями

Слайд 2





Лабораторная работа 10

Работа 10. SQL выполняется на учебной базе "sakila"
БД "sakila"  создается вручную (пустая). 
А все наполнение – при помощи SQL-инструкций из файлов 1.sql и 2.sql
Описание слайда:
Лабораторная работа 10 Работа 10. SQL выполняется на учебной базе "sakila" БД "sakila" создается вручную (пустая). А все наполнение – при помощи SQL-инструкций из файлов 1.sql и 2.sql

Слайд 3





Соединение с БД
1. Соединение с сервером БД
	$lnk= mysql_connect("localhost", "username", "password")
 		or die("Couldnotconnect: " . mysql_error());
 
2. Выбор БД
	mysql_select_db("dbname", $lnk)
		or die('Can\'t usedbname: '. mysql_error());
Часто выносится в отдельный файл, подключаемый require_once("db_connect.php");
Описание слайда:
Соединение с БД 1. Соединение с сервером БД $lnk= mysql_connect("localhost", "username", "password") or die("Couldnotconnect: " . mysql_error());   2. Выбор БД mysql_select_db("dbname", $lnk) or die('Can\'t usedbname: '. mysql_error()); Часто выносится в отдельный файл, подключаемый require_once("db_connect.php");

Слайд 4





Проверка текущей ситуации на странице
Читаем шаблон формы в строковую переменную $page;
Проверяем – мы пришли по кнопке Submit?
// МЫ ВПЕРВЫЕ НА СТРАНИЦЕ?
    if(isset($_POST['submit'])) // нет, не впервые
Описание слайда:
Проверка текущей ситуации на странице Читаем шаблон формы в строковую переменную $page; Проверяем – мы пришли по кнопке Submit? // МЫ ВПЕРВЫЕ НА СТРАНИЦЕ? if(isset($_POST['submit'])) // нет, не впервые

Слайд 5





Заполнение переменных из глобальных массивов
Переносим массивы $_POST и $_GET в переменные
	так:
$chcat = isset($_POST['chcat']) ? true:false;
$chrat = isset($_POST['chrat']) ? true:false;
$chlong = isset($_POST['chlong']) ? true:false;
$chprice = isset($_POST['chprice']) ? true:false;
	или так:
extract($_POST);
Описание слайда:
Заполнение переменных из глобальных массивов Переносим массивы $_POST и $_GET в переменные так: $chcat = isset($_POST['chcat']) ? true:false; $chrat = isset($_POST['chrat']) ? true:false; $chlong = isset($_POST['chlong']) ? true:false; $chprice = isset($_POST['chprice']) ? true:false; или так: extract($_POST);

Слайд 6





Изменения в БД
Если есть массив $_POST – выполняем действия для кнопки Submit (например, добавляем запись)
Если есть $_GET – выполняем действия для гиперссылки (например, удаляем запись)
В обоих случаях нам придется сформировать запрос и отправить его на выполнение.
Описание слайда:
Изменения в БД Если есть массив $_POST – выполняем действия для кнопки Submit (например, добавляем запись) Если есть $_GET – выполняем действия для гиперссылки (например, удаляем запись) В обоих случаях нам придется сформировать запрос и отправить его на выполнение.

Слайд 7





Отображение данных на странице
Формируем запрос SELECT для выборки
(можно изначально сделать фиксированный запрос, например
 $sql = "SELECT `film`.`film_id`,`title`,`rental_rate`,`length`,`rating`,`category_id` ";
    $sql .= "FROM `film`,`film_category` ";
    $sql .= "WHERE `rental_rate` > 2 AND `rental_rate` < 3 ";
    $sql .= "AND `length` > 100 AND `length` < 200 ";
    $sql .= "AND `rating` = 'G' ";
    $sql .= "AND `category_id` = 1 ";
    $sql .= "AND `film`.`film_id` = `film_category`.`film_id` ";
    $sql .= "LIMIT 0, 30";
чтобы убедиться, что все работает. А затем постепенно подставлять значения полей.
Описание слайда:
Отображение данных на странице Формируем запрос SELECT для выборки (можно изначально сделать фиксированный запрос, например $sql = "SELECT `film`.`film_id`,`title`,`rental_rate`,`length`,`rating`,`category_id` "; $sql .= "FROM `film`,`film_category` "; $sql .= "WHERE `rental_rate` > 2 AND `rental_rate` < 3 "; $sql .= "AND `length` > 100 AND `length` < 200 "; $sql .= "AND `rating` = 'G' "; $sql .= "AND `category_id` = 1 "; $sql .= "AND `film`.`film_id` = `film_category`.`film_id` "; $sql .= "LIMIT 0, 30"; чтобы убедиться, что все работает. А затем постепенно подставлять значения полей.

Слайд 8





Отображение данных на странице
Выполняем запрос 
	$result = mysql_query($sql);
В цикле каждую строку запроса переноси в массив (здесь – ассоциативный)
	while($date = mysql_fetch_assoc($result))
Формируем строку для вывода на страницу:
	$str = $date['id']." ".$date['name']."<br>";
Заменяем плейсхолдер на странице на полученную строку:
	$page = str_replace('{max}', $str, $page);
Выводим страницу  
    echo $page;
ВСЕ!
Описание слайда:
Отображение данных на странице Выполняем запрос $result = mysql_query($sql); В цикле каждую строку запроса переноси в массив (здесь – ассоциативный) while($date = mysql_fetch_assoc($result)) Формируем строку для вывода на страницу: $str = $date['id']." ".$date['name']."<br>"; Заменяем плейсхолдер на странице на полученную строку: $page = str_replace('{max}', $str, $page); Выводим страницу echo $page; ВСЕ!

Слайд 9





Задание 2
Требуется сразу же заполнить 2 списка и 4 поля:
Для получения диапазона продолжительности и цены используйте операции MIN и MAX
$sql = "SELECT MIN(`len`) minlen FROM `film`;";
Описание слайда:
Задание 2 Требуется сразу же заполнить 2 списка и 4 поля: Для получения диапазона продолжительности и цены используйте операции MIN и MAX $sql = "SELECT MIN(`len`) minlen FROM `film`;";

Слайд 10





Задание 2
Для получения списка постройте запрос, который вернет все категории или все варианты рейтинга:
$sql="SELECT DISTINCT `r` FROM `film`;";
И заполните соответствующий плейсхолдер, добавляя теги списка:
$optionrat .= "<option ".$date[rating]."</option>";//в цикле 
...
$page = str_replace('{optionrat}', $optionrat, $page);
Описание слайда:
Задание 2 Для получения списка постройте запрос, который вернет все категории или все варианты рейтинга: $sql="SELECT DISTINCT `r` FROM `film`;"; И заполните соответствующий плейсхолдер, добавляя теги списка: $optionrat .= "<option ".$date[rating]."</option>";//в цикле ... $page = str_replace('{optionrat}', $optionrat, $page);

Слайд 11





Задание 2. 
Для профессионалов
При повторном вызове формы хорошо помнить выбранный элемент списка:
$optionrat .= "<option ".(($rat == $date[rating])?"selected ":"")."value = '$date[rating]'> $date[rating] </option>";
Описание слайда:
Задание 2. Для профессионалов При повторном вызове формы хорошо помнить выбранный элемент списка: $optionrat .= "<option ".(($rat == $date[rating])?"selected ":"")."value = '$date[rating]'> $date[rating] </option>";

Слайд 12





Задание 2
При построении запроса для выбора фильма должны срабатывать только те фильтры, возле которых помечены checkbox-ы. Поэтому сначала формируем начало инструкции SQL:
$sql = "SELECT `film`.`film_id`,`title`,`rental_rate`,".
"`length`,`rating`,`category_id` FROM `film`,`film_category` ".
"WHERE `film`.`film_id` = `film_category`.`film_id` ";
А затем добавляем фильтры:
if ($chcat) $sql .= " AND `category_id` = '$cat'";
Описание слайда:
Задание 2 При построении запроса для выбора фильма должны срабатывать только те фильтры, возле которых помечены checkbox-ы. Поэтому сначала формируем начало инструкции SQL: $sql = "SELECT `film`.`film_id`,`title`,`rental_rate`,". "`length`,`rating`,`category_id` FROM `film`,`film_category` ". "WHERE `film`.`film_id` = `film_category`.`film_id` "; А затем добавляем фильтры: if ($chcat) $sql .= " AND `category_id` = '$cat'";

Слайд 13





Задание 2
При разборе запроса просто выводим все поля через пробел и добавляем переход на новую строку:
$date = array_values($date);
for($i=0; $i<count($date); $i++)
{
   $str_info .= $date[$i]." ";
}
$str_info .="<br>";
Описание слайда:
Задание 2 При разборе запроса просто выводим все поля через пробел и добавляем переход на новую строку: $date = array_values($date); for($i=0; $i<count($date); $i++) { $str_info .= $date[$i]." "; } $str_info .="<br>";

Слайд 14





Задание 3
Здесь все кнопки имеют одно имя, но разные значения.
Выбор можно построить через switch
switch($m)
{
   case 1: // Суммарная продолжительность фильмов в каждой категории
                                break;
   case 2: // К-во фильмов по каждому прайсу
                               break;
   case 3: // Все страны, для которых количество городов в базе > 10
                                break;
   case 4: // top10 актеров, снявшихся в максимальном количестве фильмов
Описание слайда:
Задание 3 Здесь все кнопки имеют одно имя, но разные значения. Выбор можно построить через switch switch($m) { case 1: // Суммарная продолжительность фильмов в каждой категории break; case 2: // К-во фильмов по каждому прайсу break; case 3: // Все страны, для которых количество городов в базе > 10 break; case 4: // top10 актеров, снявшихся в максимальном количестве фильмов

Слайд 15





Задание 3
Получение первой буквы в имени:
LEFT(`country`,1)
Для любого вычисляемого поля можно добавить альтернативное имя и затем использовать его в выражениях:
$sql = "SELECT `country`, COUNT(`city_id`) cc ";
...
$sql .= "HAVING cc > 10;";
Описание слайда:
Задание 3 Получение первой буквы в имени: LEFT(`country`,1) Для любого вычисляемого поля можно добавить альтернативное имя и затем использовать его в выражениях: $sql = "SELECT `country`, COUNT(`city_id`) cc "; ... $sql .= "HAVING cc > 10;";

Слайд 16





Задание 4
Поскольку списки здесь взаимосвязаны (перечень городов зависит от страны), введена кнопка ОБНОВИТЬ.
Для добавления записи в таблицу `customer` нужно иметь последний ID при добавлении в таблицу `address`: 
$sql = "SELECT LAST_INSERT_ID();";
Описание слайда:
Задание 4 Поскольку списки здесь взаимосвязаны (перечень городов зависит от страны), введена кнопка ОБНОВИТЬ. Для добавления записи в таблицу `customer` нужно иметь последний ID при добавлении в таблицу `address`: $sql = "SELECT LAST_INSERT_ID();";

Слайд 17


Запросы с групповыми операциями, слайд №17
Описание слайда:

Слайд 18


Запросы с групповыми операциями, слайд №18
Описание слайда:

Слайд 19


Запросы с групповыми операциями, слайд №19
Описание слайда:

Слайд 20


Запросы с групповыми операциями, слайд №20
Описание слайда:

Слайд 21


Запросы с групповыми операциями, слайд №21
Описание слайда:



Похожие презентации
Mypresentation.ru
Загрузить презентацию