Контакты

Основы SQL для начинающих с уроками. SQL SELECT и запросы на выборку данных Запросы в запросе sql select

Для считывания данных из базы данных и вывода их на Web-странице РНР-сценарий должен выполнить три операции. Во-первых, сценарий должен установить соединение с СУБД с помощью вызова встроенной функции соединения с базой данных, например, функции mysql_connect(), которая позволяет установить соединение с СУБД MySQL. Во-вторых, сценарий должен по установленному соединению с СУБД отправить запрос с помощью встроенной функции отправки SQL-запроса, например, функции mysql_query(), которая позволяет PHP-сценарию передавать на выполнение СУБД операторы SQL. В-третьих, после помещения СУБД результатов запроса в выходной буфер Web-сервера сценарий должен считать данные из буфера и вывести их на Web-странице. Например, при работе с MySQL сценарий может использовать встроенную функцию mysql_fetch_array(), которая считывает строку результатов SQL-запроса из буфера СУБД и помещает значения столбцов строки в массив элементов. Затем, сценарий может выполнить оператор echo или вызывать функцию print() для вывода значений полей таблицы базы данных на Web-страницу.

Предположим, например, что используется СУБД MySQL и в HTML-таблице на Web-странице необходимо вывести данные из SQL-таблицы с именем «Продукты», содержащейся в базе данных «Товары». Прежде всего, нужно выполнить вызов функции mysql_connect() следующего вида:

$link = mysql_connect($db_host, $db_user, $db_pass);

$db_host содержит строку "localhost" (если сервер MySQL находится на том же компьютере, что и Web-сервер) или строку с IP-адресом компьютера, где находится сервер MySQL, с которым необходимо установить соединение. (Для получения IP-адреса сервера MySQL нужно связаться с Internet-провайдером.) Остальные два аргумента, $db_user и $db_pass, содержат имя пользователя и пароль, необходимые функции mysql_connect() для установки соединения с СУБД MySQL. При работе с СУБД MySQL с аргументами, установленными по умолчанию, войти в базу данных можно с именем пользователя $db_user="root" и паролем $db_pass="password".

Инструкция с функцией mysql_connect() присваивает переменной $link идентификатор соединения с СУБД или значение false, если попытка установить соединение не удалась. Поскольку время от времени случаются ошибки, с помощью оператора if нужно проверить значение переменной $link, и в случае необходимости выведите на экран сообщение об ошибке. Если попытка установки соединения завершается успешно, для выбора базы данных с таблицами, данные которых будут считываться в запросе, можно воспользоваться вызовом функции, приведенным в следующем примере:

if (!mysql_select_db($db_name, $link)

// Инструкции, обрабатывающие случай неудавшейся попытки

// использования базы данных

// Обработка после успешной установки соединения и выбора

// базы данных

Сервер MySQL, как правило, поддерживает несколько баз данных, поэтому нужно выбрать базу данных, содержащую нужные таблицы. В приведенном примере $db_name содержит строку "Товары", a $link - идентификатор соединения с базой данных, возвращенный функцией mysql_connect(). Как и ранее, необходимо проверить данные, возвращаемые PHP-функцией (в данном примере функцией mysql_select_db()), чтобы убедиться, что выбор базы данных был выполнен успешно. Функция mysql_select_db() возвращает true при успешном выборе базы данных и false - в противном случае.

После успешной установки соединения с СУБД MySQL и выбора базы данных для выполнения запроса нужно вызвать функцию mysql_query(), как показано в следующем примере:

$result = mysql_query($query, $link);

В приведенном примере, в котором считывается содержимое таблицы products, аргумент $query содержит SQL-команду:

SELECT * FROM Продукты ORDER BY название

Как и ранее, параметр $link содержит идентификатор соединения с базой данных, возвращенный успешно выполненной функцией mysql_connect(), вызов которой находится в начале сценария. Функция mysql_query() возвращает false (если СУБД по какой-то причине не смогла выполнить переданный ей SQL-оператор) или указатель на место, куда СУБД поместила результаты выполнения запроса.

Для считывания результатов запроса (т. е. строк данных, которые запрос выбрал из таблицы products) нужно несколько раз вызвать функцию mysql_fetch_array() для считывания всех строк результатов запроса и сохранения их в массиве. Затем нужно вывести данные из массива на Web-страницу. Например, следующий сценарий извлекает количество полей (возвращенных в результатах запроса), их имена и типы, и выводит значения столбцов, содержащихся в результатах запроса, в виде HTML-таблицы, которую сценарий создает на Web-странице:

// Определить количество полей, возвращенных в результате запроса

$fields = mysql_num_f ields ($result);

// Начать определение HTML-таблицы

echo "

" ;

// Вывести на экран названия столбцов в виде заголовков

// HTML-таблицы

echo "

";

for ($i = 0 ; $i < $fields; $i++)

echo "

";

$fieldType[$i] =mysql_field_type($result,$i) ;

echo "

";

// Вывести в HTML-таблице результаты запроса

while ($array = mysql_fetch_array ($result))

echo "

";

for ($i = 0; $i < $fields; $i ++)

if ($fieldType[$i] <> "string")

echo "

";

echo "

";

echo "

" . mysql_field_name($result, $i) . "
";

echo "

" ;

echo "$array[$i]

";

Сценарий выводит на экран названия столбцов, возвращенных запросом, в виде заголовков столбцов таблицы, а сами результаты запроса помещаются в строки таблицы.

Задание

Создать базу данных в программе Devart dbForge Studio for MySQL в соответствии с вариантом задания (табл. 1). Написать программу на языке PHP, которая считывает данные из этой базы и отображает их в виде таблицы (рис.1).

Программа должна быть сохранена в файле “d:\server\www\index.php”. База данных должна находиться в директории “d:\server\mysql\data”. Запускать программу из браузера, введя URL-адрес” http://localhost”.

Таблица 1 – Варианты заданий

Вариант Задание
Паспортный стол. Таблица должна обладать следующими реквизитами. - № паспорта (обязательное поле); - ФИО (обязательное поле); - Дата рождения (обязательное поле); - Дата выдачи паспорта (обязательное поле); - адрес; - телефон.
Автосалон. Таблица должна обладать следующими реквизитами. - Фирма-производитель (обязательное поле); - модель машины (обязательное поле); - объем двигателя; - текущая стоимость; - признак наличия в продаже;
Библиотека. - Инвентарный номер книги (обязательное поле); - Автор (обязательное поле); - Название (обязательное поле); - Стоимость (обязательное поле); - Жанр; - Дата поступления в библиотечный фонд.
Автовокзал. - Номер рейса (обязательное поле); - Пункт отправления (обязательное поле); - Пункт прибытия (обязательное поле); - Время прибытия на данную станцию (обязательное поле); - Время отправления (обязательное поле);
Животные заповедника - Название животного (обязательное поле); - Численность; - Занесено ли в красную книгу (обязательное поле); - Средняя продолжительность жизни;
Видеотека - Название фильма (обязательное поле); - Режиссер (обязательное поле); - Год выпуска; - Жанр; - Краткое описание;
ЖЭК - № ЖЭКа (обязательное поле); - Начальник (обязательное поле); - Численность персонала; - Кол-во обслуживаемых квартир (обязательное поле); - Кол-во ремонтных бригад;
Предметы в ВУЗе - Название (обязательное поле); - Лектор (обязательное поле); - Кафедра; - Количество часов (обязательное поле); - Признак экзамен или зачет;
Прайс-лист - Категория (обязательное поле) (напр., материнская плата, процессор и т.д.); - Код товара (обязательное поле); - Фирма-производитель (обязательное поле); - Название товара (обязательное поле); - Цена (обязательное поле); - Признак наличия в продаже(обязательное поле);
Меню - Название блюда (обязательное поле); - Вес/объем блюда (обязательное поле); - Цена (обязательное поле); - Время приготовления; - Наличие в данный момент (обязательное поле);

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

SELECT для выбора столбцов таблицы

Запрос с оператором SELECT для выбора всех столбцов таблицы имеет следующий синтаксис:

SELECT * FROM ИМЯ_ТАБЛИЦЫ

То есть для выбора всех столбцов таблицы после слова SELECT нужно ставить звёздочку.

Пример 1. Есть база данных фирмы - Company. В ней есть таблица Org (Структура фирмы) и Staff (Сотрудники). Требуется выбрать из таблиц все столбцы. Соответствующий запрос для выбора всех столбцов из таблицы Org выглядит следующим образом:

SELECT * FROM ORG

Этот запрос вернёт следующее (для увеличения картинки щёлкнуть по ней левой кнопкой мыши):

Запрос для выбора всех столбцов из таблицы Staff выглядит следующим образом:

SELECT * FROM STAFF

Этот запрос вернёт следующее:


Для выбора определённых столбцов таблицы нам потребуется вместо звёздочки перечислить через запятую названия всех столбцов, которые требуется выбрать:

SELECT ВЫБИРАЕМЫЕ_СТОЛБЦЫ FROM ИМЯ_ТАБЛИЦЫ

Пример 2. Пусть требуется из таблицы Org выбрать столбцы Depnumb и Deptname, в которых содержатся данные соответственно о номерах отделов фирмы и об их названиях. Запрос для получения такой выборки будет следующим:

SELECT DEPNUMB, DEPTNAME FROM ORG

А из таблицы Staff нужно выбрать столбцы DEPT, NAME, JOB, в которых содержатся соответственно данные о номере отдела, в котором трудится сотрудник, его имени и должности:

SELECT DEPT, NAME, JOB FROM STAFF

Для выбора определённых строк таблицы вместе с оператором SELECT уже потребуется ключевое слово WHERE, указывающее на некоторое значение или несколько значений, содержащиеся в интересующих нас строках. Наиболее простые условия задаются при помощи операторов сравнения и равенства (, =), а также ключевого слова IS. Условий может быть несколько, тогда они перечисляются с использованием ключевого слова AND. Запросы для выбора строк имеют следующий синтаксис:

Пример 4. В предыдущем примере мы выбирали строки из таблицы только по значению одного столбца - DEPT. Пусть теперь нужно выбрать данные о сотрудниках, которые работают в 38-м отделе и должность которых - служащий (Clerk). Для этого в секции WHERE соответствующие значения нужно перечислить с использованием слова AND:


Пример 5. Пусть нужно выбрать из таблицы Staff идентификаторы и имена тех сотрудников, размер комиссии которых - неопределённый. Для этого в секции WHERE перед указанием значения столбца COMM - NULL нужно ставить не знак равенства, а слово IS:

Этот запрос вернёт следующие данные:


Для указания значений в строках, которые требуется выбрать, используются и знаки сравнения.

Использование SELECT и предикатов IN, OR, BETWEEN, LIKE

Предикаты - слова IN, OR, BETWEEN, LIKE в секции WHERE - также позволяют выбрать определённые диапазоны значений (IN, OR, BETWEEN) или значения в строках (LIKE), которые требуется выбрать из таблицы. Запросы с предикатами IN, OR, BETWEEN имеют следующий синтаксис:

Запросы с предикатом LIKE имеют следующий синтаксис:

Пример 7. Пусть требуется выбрать из таблицы Staff имена, должности и число отработанных лет сотрудников, работающих в отделах с номерами 20 или 84. Это можно сделать следующим запросом:

Результат выполнения запроса:


Пример 8. Пусть теперь требуется выбрать из таблицы Staff те же данные, что и в предыдущем примере. Запрос со словом OR аналогичен запросу со словом IN и перечислением интересующих значений в скобках. Запрос будет следующим:

Пример 9. Выберем из той же таблицы имена, должности и число отработанных лет сотрудников, зарплата которых между 15000 и 17000 включительно:

Результат выполнения запроса:


Предикат LIKE используется для выборки тех строк, в значениях которых встречаются символы, указанные после предиката между апострофами (").

Пример 10. Выберем из той же таблицы имена, должности и число отработанных лет сотрудников, имена которых начинаются с буквы S и состоят из 7 символов:

Символ подчёркивания (_) означает любой символ. Результат выполнения запроса:


Пример 11. Выберем из той же таблицы имена, должности и число отработанных лет сотрудников, имена которых начинаются с буквы S и содержат любые другие буквы в любом количестве:

Символ процентов (%) означает любое количество символов. Результат выполнения запроса:


Значения, указанные с использованием предикатов IN, OR, BETWEEN, LIKE можно инвертировать при помощи слова NOT. Тогда запрашиваемые данные будут иметь противоположный смысл. Если мы используем NOT IN (20, 84), то будут выведены данные сотрудников, которые работают во всех отделах, кроме имеющих номера 20 и 84. С использованием NOT BETWEEN 15000 AND 17000 можно получить данные сотрудников, зарплата которых не входит в интервал от 15000 до 17000. Запрос с NOT LIKE выведет данные сотрудников, чьи имена не начинаются или не содержат символов, указанных с NOT LIKE.

Написать SQL запросы с SELECT и предикатами IN, NOT IN, BETWEEN самостоятельно, а затем посмотреть решения

Есть база данных "Театр". Таблица Play содержит данные о постановках. Таблица Team - о ролях актёров. Таблица Actor - об актёрах. Таблица Director - о режиссёрах. Поля таблиц, первичные и внешние ключи можно увидеть на рисунке ниже (для увеличения нажать левой кнопкой мыши).


Пример 12. Вывести список актёров, которые не разу не были утверждены на главную роль. В таблице team данные о главных ролях содержатся в столбце mainteam. Если роль - главная, то в соответствующей строке отмечено "Y".

SELECT и ORDER BY - сортировка (упорядочение) строк

Разобранные до сих пор запросы SQL SELECT возвращали строки, которые могли быть расположены в любой последовательности. Однако часто требуется отсортировать строки по порядку номеров, алфавиту и другим признакам. Для этого служит ключевое словосочетание ORDER BY. Такие запросы имеют следующий синтаксис:

Пример 15. Пусть требуетя выбрать из таблицы Staff сотрудников, работающих в отделе с номером 84 и отсортировать (упорядочить) записи по числу отработанных лет в возрастающем порядке:

Слово ASC указывает, что порядок сортировки - возрастающий. Это слово не обязательно, так как возрастающий порядок сортировки применяется по умолчанию. Результат выполнения запроса:


Пример 16. Пусть требуетя выбрать те же данные, что и в предыдущем примере, но отсортировать (упорядочить) записи по числу отработанных лет в убывающем порядке:

Слово DESC указывает, что порядок сортировки - убывающий. Результат выполнения запроса:


SELECT и DISTINCT - удаление дубликатов строк

Когда для значений строк таблицы не задано условие уникальности, в результатах запроса могут встретиться одинаковые строки. Часто требуется вывести лишь уникальные строки. Это делается при помощи выражения DISTINCT после оператора SELECT.

Пример 17. Пусть требуетcя узнать, какие существуют отделы и какие должности среди отделов, номера которых меньше 30. Это можно сделать при помощи следующего запроса:

Результат выполнения запроса:


Оператор SELECT в подзапросах SQL

До сих пор мы разбирали конструкции SQL с оператором SELECT, в которых условия, по котором выбираются данные, и сами выбираемые данные содержатся в одной и той же таблице базы данных. На практике часто бывает, что данные, которые надо выбрать, содержатся в одной таблице, а условия - в другой. Здесь на помощь приходят подзапросы: значения условия отбора возвращаются из другого запроса (вложенного запроса), начинающегося также с SELECT. Запросы с подзапросами могут выдавать как одну, так и несколько строк.

Пример 18. Все те же таблицы ORG и STAFF. Пусть требуетcя узнать, в каком подразделении работает сотрудник с идентификационным номером 280, и где это подразделение расположено. Но информация о подразделениях хранится в таблице ORG, а информация о сотрудниках - в таблице STAFF. Это можно сделать при помощи следующего запроса с подзапросом, в котором внешний SELECT обращается к таблице ORG, а внутренний SELECT - к таблице STAFF:

Результат выполнения запроса:


Пример 19. Пусть теперь требуетcя узнать, в каких подразделениях (без дублирования) работают сотрудники с заработной платой менее 13000. Для этого в секции WHERE внешнего SELECT (запрос к таблице ORG) задаётся условие, принимающее диапазон значений (IN), а внутренний SELECT (к таблице STAFF) как раз возвращает требуемый диапазон значений:

Реляционные базы данных и язык SQL

Любая таблица имеет своё логическое начало и свой логический конец. Так же любая таблица состоит из данных, которые за частую, а в случае с базами данных в большей степени, расположены в разброс. Как отмечалось в первой записи касательно SQL и баз данных, данные могут вноситься регулярно, на протяжении всего жизненного цикла баз данных. За это время может быть внесён не один десяток данных. В SQL, как в прочем и во всех компьютерных программах, можно упорядочивать данные. Делается это по средствам команды ORDER BY . Для данной команды существуют два аргумента

  • ASC задаёт порядок по возрастанию (от меньшего к большему)
  • DESC - по убыванию (от большего к меньшему)
Вообще в SQL по умолчанию установлено упорядочивание по возрастанию (от меньшего к большему).
Попробуем упорядочить таблицу должников по фамилии - столбец Sname - по убыванию

Debtors

Num Month Year Sname City Address Penalty Debt
0001 Июль 2012 Иванов Ставрополь Ставропольская, 1 4891.00 50000
0002 Декабрь 2019 Кононов Татарка Загородная, 254 19565.00 684068
0003 Май 2013 Ямшин Михайловск Сельская, 48 9868.00 165840
0004 Август 2012 Прени Ставрополь Центральная, 16 4659.00 46580
... ... ... ... ... ... ... ...
9564 Март 2015 Улиева Дёмино Международная, 156 6846.00 435089
9565 Октябрь 2012 Павлова Ставрополь Вокзальная, 37 685.00 68059
9566 Январь 2012 Урюпа Михайловск Фонтанная, 19 1235.00 51238
9567 Ноябрь 2017 Вальетов Татарка Выездная, 65 13698.00 789654

Выполняем запрос
SELECT *
FROM Debtors
ORDER BY Sname DESC ;

Debtors

Num Month Year Sname City Address Penalty Debt
0003 Май 2013 Ямшин Михайловск Сельская, 48 9868.00 165840
9566 Январь 2012 Урюпа Михайловск Фонтанная, 19 1235.00 51238
9564 Март 2015 Улиева Дёмино Международная, 156 6846.00 435089
0004 Август 2012 Прени Ставрополь Центральная, 16 4659.00 46580
9565 Октябрь 2012 Павлова Ставрополь Вокзальная, 37 685.00 68059
0002 Декабрь 2019 Кононов Татарка Загородная, 254 19565.00 684068
0001 Июль 2012 Иванов Ставрополь Ставропольская, 1 4891.00 50000
9567 Ноябрь 2017 Вальетов Татарка Выездная, 65 13698.00 789654

Так же упорядочивание может выполняться и в группируемых данных, по средством команды . Но в таком случае, команда ORDER BY в запросе должна стоять последней, то есть
SELECT *
FROM Debtors
GROUP BY Sname
ORDER BY Sname DESC ;

Если же в упорядочиваемых полях имеются ячейки с пустыми значениями (NULL), то, в зависимости от программ, работающих с БД, такие ячейки могут располагаться либо в конце списка, либо в начале.
Существует ещё одна хитрость по выполнению упорядочивания данных. Рассмотрим запрос
SELECT Num, Year, Sname
FROM Debtors
ORDER BY 2 DESC ;

Здесь под двойкой подразумевается порядковый номер столбца из строки "SELECT Num, Year, Sname" и именно по этому столбцу будет выполняться ранжирование по убыванию в итоге

Debtors

Как видно, значения упорядочились по столбцу Year, где в начале списка более поздняя дата.
Итак, упорядочивание в SQL имеет те же принципы ранжирования, что и в любых компьютерных программах. Всё зависит от администратора БД и его потребностей в той или иной информации, которую он хочет получить.



Содержание статьи
1. Самые простые MySQL запросы
2. Простые SELECT (выбрать) запросы
3. Простые INSERT (новая запись) запросы
4. Простые UPDATE (перезаписать, дописать) запросы
5. Простые DELETE (удалить запись) запросы
6. Простые DROP (удалить таблицу) запросы
7. Сложные MySQL запросы
8. MySQL запросы и переменные PHP

1. Самые простые SQL запросы

1. Выведет список ВСЕХ баз.

SHOW databases;
2. Выведет список ВСЕХ таблиц в Базе Данных base_name.

SHOW tables in base_name;

2. Простые SELECT (выбрать) запросы к базе данных MySQL

SELECT – запрос, который выбирает уже существующие данные из БД. Для выбора можно указывать определённые параметры выбора. Например, суть запроса русским языком звучит так - ВЫБРАТЬ такие-то колонки ИЗ такой-то таблицы ГДЕ параметр такой-то колонки равен значению.

1. Выбирает ВСЕ данные в таблице tbl_name.

SELECT * FROM tbl_name;
2. Выведет количество записей в таблице tbl_name.

SELECT count(*) FROM tbl_name;
3. Выбирает (SELECT) из(FROM) таблицы tbl_name лимит (LIMIT) 3 записи, начиная с 2.

SELECT * FROM tbl_name LIMIT 2,3;
4. Выбирает (SELECT) ВСЕ (*) записи из (FROM) таблицы tbl_name и сортирует их (ORDER BY) по полю id по порядку.

SELECT * FROM tbl_name ORDER BY id;
5. Выбирает (SELECT) ВСЕ записи из (FROM) таблицы tbl_name и сортирует их (ORDER BY) по полю id в ОБРАТНОМ порядке.

SELECT * FROM tbl_name ORDER BY id DESC;
6. Выбирает (SELECT ) ВСЕ (*) записи из (FROM ) таблицы users и сортирует их (ORDER BY ) по полю id в порядке возрастания, лимит (LIMIT ) первые 5 записей.

SELECT * FROM users ORDER BY id LIMIT 5;
7. Выбирает все записи из таблицы users , где поле fname соответствует значению Gena .

SELECT * FROM users WHERE fname="Gena";
8. Выбирает все записи из таблицы users , где значение поля fname начинается с Ge .

SELECT * FROM users WHERE fname LIKE "Ge%";
9. Выбирает все записи из таблицы users , где fname заканчивается на na , и упорядочивает записи в порядке возрастания значения id .

SELECT * FROM users WHERE fname LIKE "%na" ORDER BY id;
10. Выбирает все данные из колонок fname , lname из таблице users .

SELECT fname, lname FROM users;

11. Допустим у Вас в таблице пользовательских данных есть страна. Так вот если Вы хотите вывести ТОЛЬКО список встречающихся значений (чтобы, например, Россия не выводилось 20 раз, а только один), то используем DISTINCT. Выведет, из массы повторяющихся значений Россия, Украина, Беларусь. Таким образом, из таблицы users колонки country будут выведены ВСЕ УНИКАЛЬНЫЕ значения

SELECT DISTINCT country FROM users;
12. Выбирает ВСЕ данные строк из таблицы users где age имеет значения 18,19 и 21.

SELECT * FROM users WHERE age IN (18,19,21);
13. Выбирает МАКСИМАЛЬНОЕ значение age в таблице users . То есть если у Вас в таблице самое большее значение age (с англ. возраст) равно 55, то результатом запроса будет 55.

SELECT max(age) FROM users;
14. Выберет данные из таблицы users по полям name и age ГДЕ age принимает самое маленькое значение.

SELECT name, min(age) FROM users;
15. Выберет данные из таблицы users по полю name ГДЕ id НЕ РАВЕН 2.

SELECT name FROM users WHERE id!="2";

3. Простые INSERT (новая запись) запросы

INSERT – запрос, который позволяет ПЕРВОНАЧАЛЬНО вставить запись в БД. То есть создаёт НОВУЮ запись (строчку) в БД.

1. Делает новую запись в таблице users , в поле name вставляет Сергей, а в поле age вставляет 25. Таким образом, в таблицу дописывается новая строки с данными значениями. Если колонок больше, то они оставшиеся останутся либо пустыми, либо с установленными по умолчанию значениями.

INSERT INTO users (name, age) VALUES ("Сергей", "25");

4. Простые UPDATE запросы к базе данных MySQL

UPDATE – запрос, который позволяет ПЕРЕЗАПИСАТЬ значения полей или ДОПИСАТЬ что-то в уже существующей строке в БД. Например, есть готовая строка, но в ней нужно перезаписать параметр возраста, так как он изменился со временем.

1. В таблице users age становится 18.

UPDATE users SET age = "18" WHERE id = "3";
2. Всё то же самое, что и в первом запросе, просто показан синтаксис запроса, где перезаписываются два поля и более.
В таблице users ГДЕ id равно 3 значение поля age становится 18, а country Россия.

UPDATE users SET age = "18", country = "Россия" WHERE id = "3";

5. Простые DELETE (удалить запись) запросы к базе данных MySQL

DELETE – запрос, который удаляет строку из таблицы.

1. Удаляет строку из таблицы users ГДЕ id равен 10.

DELETE FROM users WHERE id = "10";

6. Простые DROP (удалить таблицу) запросы к базе данных MySQL

DROP – запрос, который удаляет таблицу.

1. Удаляет целиком таблицу tbl_name .

DROP TABLE tbl_name;

7. Сложные запросы к базе данных MySQL

Любопытные запросы, которые могут пригодиться даже опытным пользователям

SELECT id,name,country FROM users,admins WHERE TO_DAYS(NOW()) - TO_DAYS(registration_date) <= 14 AND activation != "0" ORDER BY registration_date DESC;
Данный сложный запрос ВЫБИРАЕТ колонки id,name,country В ТАБЛИЦАХ users,admins ГДЕ registration_date (дата) не старше 14 дней И activation НЕ РАВНО 0 , СОРТИРОВАТЬ по registration_date в обратном порядке (новое в начале).

UPDATE users SET age = "18+" WHERE age = (SELECT age FROM users WHERE male = "man");
Выше указан пример так называемого запроса в запросе в SQL. Обновить возраст среди пользователей на 18+, где пол - мужской. Подобные варианты запроса не рекомендую. По личному опыту скажу, лучше создать несколько отдельных - они будут прорабатываться быстрее.

8. Запросы к базе данных MySQL и PHP

В MySQL запросы в PHP странице можно вставлять переменные в качестве сравниваемых и тп значений. Пара примеров

1. Выбирает все записи из таблицы users , где поле fname соответствует значению переменной $name .

SELECT * FROM users WHERE fname="$name";
2. В таблице users ГДЕ id равно 3 значение поля age изменяется на значение переменной $age.

UPDATE users SET age = "$age" WHERE id = "3";

Внимание! Если Вам интересен какой-либо ещё пример, то пишите вопрос в комментарии!

Удаление записей

Для удаления записей из таблицы применяется оператор DELETE:

DELETE FROM имяТаблицы WHERE условие;

Данный оператор удаляет из указанной таблицы записи (а не отдельные значения столбцов), которые удовлетворяют указанному условию. Условие - это логическое выражение, различные конструкции которого были рассмотрены в предыдущих лабораторных занятиях.

Следующий запрос удаляет записи из таблицы Customer, в которой значение столбца LName равно "Иванов":

DELETE FROM Customer

WHERE LName = "Иванов"

Если таблица содержатся сведения о нескольких клиентах с фамилией Иванов, то все они будут удалены.

В операторе WHERE может находиться подзапрос на выборку данных (оператор SELECT). Подзапросы в операторе DELETE работают точно так же, как и в операторе SELECT. Следующий запрос удаляет всех клиентов из города Москва, при этом уникальный идентификатор города возвращается с помощью подзапроса.

DELETE FROM Customer

WHERE IdCity IN (SELECT IdCity FROM City WHERE CityName = "Москва" )

Transact-SQL расширяет стандартный SQL, позволяя использовать в инструкции DELETE еще одно предложение FROM. Это расширение, в котором задается соединение, может быть использовано вместо вложенного запроса в предложении WHERE для указания удаляемых строк. Оно позволяет задавать данные из второго FROM и удалять соответствующие строки из таблицы в первом предложении FROM. В частности предыдущий запрос может быть переписан следующим образом

DELETE FROM Customer

FROM Customer k INNER JOIN

Операция удаления записей из таблицы является опасной в том смысле, что связана с риском необратимых потерь данных в случае семантических (но не синтаксических) ошибок при формулировке SQL-выражения. Чтобы избежать неприятностей, перед удалением записей рекомендуется сначала выполнить соответствующий запрос на выборку, чтобы просмотреть, какие записи будут удалены. Так, например, перед выполнением рассмотренного ранее запроса на удаление не помешает выполнить соответствующий запрос на выборку.

SELECT *

FROM Customer k INNER JOIN

City c ON k.IdCity = c.IdCity AND c.CityName = "Москва"

Для удаления всех записей из таблицы достаточно использовать оператор DELETE без ключевого слова WHERE. При этом сама таблица со всеми определенными в ней столбцами сохраняется и готова для вставки новых записей. Например, следующий запрос удаляет записи обо всех товарах.

DELETE FROM Product

Задание для самостоятельной работы: Сформулируйте на языке SQL запрос на удаление всех заказов, не имеющих в составе ни одного товара (т. е. все пустые заказы).



Понравилась статья? Поделитесь ей