- Работа с MySQL в PHP
- Что такое mysqli?
- Как выглядит работа с базой данных
- Функция mysqli connect: соединение с MySQL
- Проверка соединения
- Установка кодировки
- Выполнение запросов
- Два вида запросов
- Добавление записи
- Функция insert id: как получить идентификатор добавленной записи
- Чтение записей
- Как получить сразу все записи в виде двумерного массива
- Как узнать количество записей
- Программирование сайтов на PHP, MySQL, JS
- Языки программирования сайтов
- Взаимодействие языков программирования
- Обучение программированию сайтов
Работа с MySQL в PHP
PHP поддерживает работу с базой данных MySQL. Специальные встроенные функции для работы с MySQL позволяют просто и эффективно работать с этой СУБД: выполнять любые запросы, читать и записывать данные, обрабатывать ошибки.
Сценарий, который подключается к БД, выполняет запрос и показывает результат, будет состоять всего из нескольких строк. Для работы с MySQL не надо ничего дополнительно устанавливать и настраивать; всё необходимое уже доступно вместе со стандартной поставкой PHP.
Что такое mysqli?
mysqli (MySQL Improved) — это расширение PHP, которое добавляет в язык полную поддержку баз данных MySQL. Это расширение поддерживает множество возможностей современных версий MySQL.
Как выглядит работа с базой данных
Типичный процесс работы с СУБД в PHP-сценарии состоит из нескольких шагов:
- Установить подключение к серверу СУБД, передав необходимые параметры: адрес, логин, пароль.
- Убедиться, что подключение прошло успешно: сервер СУБД доступен, логин и пароль верные и так далее.
- Сформировать правильный SQL запрос (например, на чтение данных из таблицы).
- Убедиться, что запрос был выполнен успешно.
- Получить результат от СУБД в виде массива из записей.
- Использовать полученные записи в своём сценарии (например, показать их в виде таблицы).
Функция mysqli connect: соединение с MySQL
Перед началом работы с данными внутри MySQL, нужно открыть соединение с сервером СУБД. В PHP это делается с помощью стандартной функции mysqli_connect() . Функция возвращает результат — ресурс соединения. Данный ресурс используется для всех следующих операций с MySQL.
Но чтобы выполнить соединение с сервером, необходимо знать как минимум три параметра:
Если вы следовали стандартной процедуре установки MySQL или используете OpenServer, то адресом сервера будет localhost , логином — root . При использовании OpenServer пароль для подключения — это пустая строка ‘’ , а при самостоятельной установке MySQL пароль вы задавали в одном из шагов мастера установки.
Базовый синтаксис функции mysqli_connect() :
Проверка соединения
Первое, что нужно сделать после соединения с СУБД — это выполнить проверку, что оно было успешным. Эта проверка нужна, чтобы исключить ошибку при подключении к БД. Неверные параметры подключения, неправильная настройка или высокая нагрузка заставит MySQL отвергать новые подключения. Все эти ситуации приведут к невозможности соединения, поэтому программист должен проверить успешность подключения к серверу, прежде чем выполнять следующие действия.
Соединение с MySQL устанавливается один раз в сценарии, а затем используется при всех запросах к БД.
Результатом выполнения функции mysqli_connect() будет значение специального типа — ресурс. Если подключение к MySQL не удалось, то функция mysqli_connect() вместо ресурса вернёт логическое значение типа «ложь» — false . Хорошей практикой будет всегда проверять результат выполнения этой функции и сравнивать его с ложью.
Соединение с MySQL и проверка на ошибки:
Функция mysqli_connect_error() просто возвращает текстовое описание последней ошибки MySQL.
Установка кодировки
Первым делом после установки соединения крайне желательно явно задать кодировку, которая будет использоваться при обмене данными с MySQL. Если этого не сделать, то вместо записей со значениями, написанными кириллицей, можно получить последовательность из знаков вопроса: . . Вызовите эту функцию сразу после успешной установки соединения: mysqli_set_charset($con, «utf8»);
Выполнение запросов
Установив соединение и определив кодировку мы готовы выполнить свои первые SQL-запросы. Вы уже умеете составлять корректные SQL команды и выполнять их через консольный или визуальный интерфейс MySQL-клиента. Те же самые запросы можно отправлять без изменений и из PHP-сценария. Помогут в этом несколько встроенных функций языка.
Два вида запросов
Следует разделять все SQL-запросы на две группы:
При выполнении запросов из среды PHP, запросы из второй группы возвращают только результат их исполнения: успех или ошибку.
Запросы первой группы при успешном выполнении возвращают специальный ресурс результата. Его, в свою очередь, можно преобразовать в ассоциативный массив (если нужна одна запись) или в двумерный массив (если требуется список записей).
Добавление записи
Вернёмся к нашему проекту — дневнику наблюдений за погодой. Начнём практическую работу с заполнения таблиц данными. Для начала добавим хотя бы один город в таблицу cities .
Выражение INSERT INTO используется для добавления новых записей в таблицу базы данных.
Составим корректный SQL-запрос на вставку записи с именем города, а затем выполним его путём передачи этого запроса в функцию mysqli_query() , чтобы добавить новые данные в таблицу.
Обратите внимание, что первым параметром для функции mysqli_query() передаётся ресурс подключения, полученный от функции mysqli_connect() , вторым параметром следует строка с SQL-запросом.
При запросах на изменение данных (не SELECT) результатом выполнения будет логическое значение — true или false , которое будет означать, что запрос выполнить не удалось. Для получения строки с описанием ошибки существует функция mysqli_error($link) .
Функция insert id: как получить идентификатор добавленной записи
Следующим шагом будет добавление погодной записи для нового города. Погодные записи хранит таблица weather_log, но, чтобы сослаться на город, необходимо знать идентификатор записи из таблицы cities.
Здесь пригодится функция mysqli_insert_id() . Она принимает единственный аргумент — ресурс соединения, а возвращает идентификатор последней добавленной записи.
Теперь у нас есть всё необходимое, чтобы добавить погодную запись. Вот как будет выглядеть комплексный пример с подключением к MySQL и добавлением двух новых записей:
Чтение записей
Другая частая операция при работе с базами данных в PHP — это получение записей из таблиц (запросы типа SELECT). Составим SQL-запрос, который будет использовать SELECT выражение. Затем выполним этот запрос с помощью функции mysqli_query() , чтобы получить данные из таблицы.
В этом примере показано, как вывести все существующие города из таблицы cities :
В примере выше результат выполнения функции mysqli_query() сохранён в переменной $result . В этой переменной находятся не данные из таблицы, а специальный тип данных — так называемая ссылка на результаты запроса.
Чтобы получить действительные данные, то есть записи из таблицы, следует использовать другую функцию — mysqli_fetch_array() — и передать ей единственным параметром эту самую ссылку. Теперь каждый вызов функции mysqli_fetch_array() будет возвращать следующую запись из всего результирующего набора записей в виде ассоциативного массива.
Цикл while здесь используется для «прохода» по всем записям из полученного набора записей. Значение поля каждой записи можно узнать просто обратившись по ключу этого ассоциативного массива.
Как получить сразу все записи в виде двумерного массива
Иногда бывает удобно после запроса на чтение не вызывать в цикле mysqli_fetch_array для извлечения очередной записи по порядку, а получить их сразу все одним вызовом. PHP так тоже умеет.
Функция mysqli_fetch_all($res, MYSQLI_ASSOC) вернёт двумерный массив со всеми записями из результата последнего запроса. Перепишем пример с показом существующих городов с её использованием:
Как узнать количество записей
Часто бывает необходимо узнать, сколько всего записей вернёт выполненный SQL-запрос. Это может помочь при организации постраничной навигации или просто в качестве информации. Узнать число записей поможет функция mysqli_num_rows() , которой следует передать ссылку на результат запроса.
«Доктайп» — журнал о фронтенде. Читайте, слушайте и учитесь с нами.
Программирование сайтов на PHP, MySQL, JS
В последние времена разработка сайтов менее связанна с проектированием статических страниц на HTML, CSS. Сайты более похожи на системы, которые способны автоматически формировать разметку и хранить информацию в базах данных. Каждый сайт это приложение, которое написано на программном коде. Наиболее распространенным языком программирования сайтов является PHP, о котором и будет идти речь в материалах нашего сайта. Другие языки программирования – это сопутствующие. Они не являются основными, но все же мы не можем представить современного сайта без красивых эффектов, интерактивности, анимации. Поэтому JavaScript не менее важен в разработке сайтов. Каждый элементарный блог на wordpress использует как минимум 3 языка программирования – PHP, MySQL, JS. Сейчас мы постараемся более широко рассмотреть цель и предназначение каждого из них.
Языки программирования сайтов
Вы должны знать, что существует намного больше языков, с помощью которых можно создать сайт. Мы рассмотрим минимум языков программирования, который необходим для создания сайта подобного этому (sitear.ru). Некоторые думают, что HTML и CSS это также языки веб программирования, но это не так. HTML и CSS являются языками разметки страницы. Можно сказать это языки создания дизайна сайта, предназначенные для верстки страниц, но никак не для программирования.
PHP – является наиболее популярным языком для веб разработчика. Этот язык выполняется на сервере, и как результат возвращает документы разного формата: HTML, XML, JPG, GIF, ZIP и так далее. Как видите с помощью PHP можно создавать не только динамические сайты, но также и картинки, архивы и другие типы данных. Более распространенным применением для PHP есть создание форумов, гостевых книг, веб фотоальбомов, движков сайтов, чатов, и все которые только можно представить веб-приложения. Чтобы понимать PHP, вам необходимо сначала усвоить языки разметки страниц – HTML, CSS. Также в наше время невозможно представить веб-приложений без хранения данных в едином месте – базе данных. За работу с базой данных отвечает MySQL, который взаимодействует с PHP.
MySQL – это язык программирования, который отвечает за работу с базами данных. Он также выполняется на сервере. Отдельным языком сложно назвать эту технологию. Так как с помощью MySQL мы можем подавать запросы к базе данных, и получать результат – данные, удаление данных, добавление новых, сортировка в определенном порядке, экспорт данных в отдельный файл, импорт данных и т.д. Для наглядности смотрите, как работает эта технология на примере взаимодействия всех языков.
JavaScript – это язык, отвечающий за визуальные эффекты и интерактивность HTML страницы. С самого определения видно, что этот язык программирования выполняется в браузере, то есть на клиентской стороне. Раньше он был менее популярен, с развитием интернета и увеличением скорости передачи данных, JavaScript стал неотъемлемым помощником в программировании сайтов. С помощью JS можно создавать отличные чаты, которые работают по технологии AJAX (асинхронного JavaScript). JavaScript позволяет реализовать такие эффекты как смена цвета при наведении на кнопку, ссылку. Также можно сделать эффекты сворачивания, разворачивания, перелистывания, обесцвечивания и все что только можно придумать. Все это – интерактивность, без которой сайт выглядит по дилетантски. Программирование на JS стало проще с появлением фреймворков jQuery, mootools, dojo и других. Фреймворк – это библиотека полезных инструментов, с помощью которых можно сократить программный код. Фреймворки позволяют разрабатывать приложения в десятки раз быстрее.
Взаимодействие языков программирования
Чтобы было понятнее, мы подготовили иллюстрацию, демонстрирующую, каким образом связанны PHP, MySQL и JS. Также мы включили HTML и CSS. Более детально вы узнаете, читая материалы нашего сайта.
Обучение программированию сайтов
Читая только статьи и отдельные уроки, сложно научится программированию сайтов. Поэтому рекомендуем сначала пройти курс обучения, после чего заняться практикой и расширением своих знаний. На нашем сайты вы найдете множество увлекательных курсов, уроков, видео и статей, касающихся темы программирования и создания сайтов.
Советуем вам спланировать свое обучение следующим образом:
- HTML – это основа построения веб страницы. Начните обучаться с освоения навыков верстки html страниц.
- CSS – это документ или часть кода отвечающая за стилизацию HTML элементов. Это незаменимое дополнение к HTML, которое следует изучать второстепенно.
- PHP – это серверный язык, с помощью которого можно создавать серьезные проекты. Но, не освоив техник HTML верстки, изучить PHP – нереально!
- MySQL – сопутствующий языку PHP. Его также невозможно изучить, не поняв архитектуру веб-приложения, которая базируется на HTML и PHP.
- Изучив вышеизложенные языки, приступите к изучению JavaScript, который менее важен в плане разработки. Но, JS важен в плане визуализаций и эффектов – без которых мы не можем представить современного сайта.
Внимание! Учитывайте то, что все эти языки тесно переплетены между собой. Рано или поздно вы будете встречаться с ними. И действительно хорошее веб-приложение будет разработано с участием всех этих языков программирования.
Творческих вам успехов в программировании и разработке сайтов! С ув. команда sitear.ru