PHP MySQLФункции: mysqli_query, mysqli_connect, mysqli_fetch_array
PHP имеет богатую коллекцию встроенных функций для управления MySQL базы данных.
Функция PHP mysqli_connect
Функция PHP mysql connect используется для подключения к MySQL сервер базы данных.
Он имеет следующий синтаксис.
<?php; $db_handle = mysqli_connect($db_server_name, $db_user_name, $db_password); ?>
ВОТ,
- «$db_handle» — это переменная ресурса подключения к базе данных.
- «mysqli_connect(…)» — функция подключения к базе данных PHP.
- «$server_name» — имя или IP-адрес сервера, на котором размещен хостинг. MySQL сервера.
- «$user_name» — допустимое имя пользователя в MySQL сервера.
- «$password» — действительный пароль, связанный с именем пользователя в MySQL сервера.
Функция PHP mysqli_select_db
Функция mysqli_select_db используется для выбора базы данных.
Он имеет следующий синтаксис.
<?php mysqli_select_db($db_handle,$database_name); ?>
ВОТ,
- «mysqli_select_db(…)» — это функция выбора базы данных, которая возвращает true или false.
- «$database_name» — имя базы данных.
- «$link_identifier» не является обязательным, он используется для передачи ссылки на подключение к серверу.
PHP-функция mysqli_query
Функция mysqli_query используется для выполнения SQL запросы.
Эту функцию можно использовать для выполнения следующих типов запросов;
- Вставить
- Выберите
- Обновление ПО
- удалять
Он имеет следующий синтаксис.
<?php mysqli_query($db_handle,$query) ; ?>
ВОТ,
- «mysqli_query(…)» — это функция, выполняющая SQL-запросы.
- «$query» — SQL-запрос, который необходимо выполнить.
- «$link_identifier» не является обязательным, его можно использовать для передачи ссылки на подключение к серверу.
Функция PHP mysqli_num_rows
Функция mysqli_num_rows используется для получения количества строк, возвращаемых запросом на выборку.
Он имеет следующий синтаксис.
<?php mysqli_num_rows($result); ?>
ВОТ,
- «mysqli_num_rows(…)» — функция подсчета строк.
- «$result» — это набор результатов mysqli_query.
Функция PHP mysqli_fetch_array
Функция mysqli_fetch_array используется для извлечения массивов строк из набора результатов запроса.
Он имеет следующий синтаксис.
<?php mysqli_fetch_array($result); ?>
ВОТ,
- «mysqli_fetch_array(…)» — функция для выборки массивов строк.
- «$result» — это результат, возвращаемый функцией mysqli_query.
PHP-функция mysqli_close
Функция mysqli_close используется для закрытия открытого соединения с базой данных.
Он имеет следующий синтаксис.
<?php mysqli_close($db_handle); ?>
ВОТ,
- «mysqli_close(…)» — это функция PHP.
- «$link_identifier» не является обязательным, он используется для передачи ресурса подключения к серверу.
Давайте рассмотрим практические примеры, в которых используются преимущества этих функций.
Создание MySQL база данных. Это руководство предполагает знание MySQL и SQL, если эти термины вам незнакомы, обратитесь к нашему MySQL и учебники по SQL.
Мы создадим простую базу данных под названием my_personal_contacts только с одной таблицей.
Ниже приведены шаги по созданию базы данных и таблицы.
- Подключение к MySQL используя ваш любимый инструмент доступа, например MySQL верстак, phpMyAdmin и т. д.
- Создайте базу данных с именем my_person_contacts.
- Выполните сценарий, показанный ниже, чтобы создать таблицу и вставить некоторые фиктивные данные.
<?php CREATE TABLE IF NOT EXISTS `my_contacts` ( `id` int(11) NOT NULL AUTO_INCREMENT, `full_names` varchar(255) NOT NULL, `gender` varchar(6) NOT NULL, `contact_no` varchar(75) NOT NULL, `email` varchar(255) NOT NULL, `city` varchar(255) NOT NULL, `country` varchar(255) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ; INSERT INTO `my_contacts` (`id`, `full_names`, `gender`, `contact_no`, `email`, `city`, `country`) VALUES (1, 'Zeus', 'Male', '111', 'zeus @ olympus . mt . co', 'Agos', 'Greece'), (2, 'Anthena', 'Female', '123', 'anthena @ olympus . mt . co', 'Athens', 'Greece'), (3, 'Jupiter', 'Male', '783', 'jupiter @ planet . pt . co', 'Rome', 'Italy'), (4, 'Venus', 'Female', '987', 'venus @ planet . pt . co', 'Mars', 'Italy'); ?>
Теперь у нас есть настроенная база данных, которой мы будем управлять с помощью PHP.
Чтение записей из базы данных Теперь мы создадим программу, которая печатает записи из базы данных.
<?php $dbh = mysqli_connect('localhost', 'root', 'melody'); //connect to MySQL server if (!$dbh) die("Unable to connect to MySQL: " . mysqli_error()); //if connection failed output error message if (!mysqli_select_db($dbh,'my_personal_contacts')) die("Unable to select database: " . mysqli_error()); //if selection fails output error message $sql_stmt = "SELECT * FROM my_contacts"; //SQL select query $result = mysqli_query($dbh,$sql_stmt); //execute SQL statement if (!$result) die("Database access failed: " . mysqli_error()); //output error message if query execution failed $rows = mysqli_num_rows($result); // get number of rows returned if ($rows) { while ($row = mysqli_fetch_array($result)) { echo 'ID: ' . $row['id'] . '<br>'; echo 'Full Names: ' . $row['full_names'] . '<br>'; echo 'Gender: ' . $row['gender'] . '<br>'; echo 'Contact No: ' . $row['contact_no'] . '<br>'; echo 'Email: ' . $row['email'] . '<br>'; echo 'City: ' . $row['city'] . '<br>'; echo 'Country: ' . $row['country'] . '<br><br>'; } } mysqli_close($dbh); //close the database connection ?>
Выполнение приведенного выше кода возвращает результаты, показанные на диаграмме ниже.
Вставка новых записей
Давайте теперь рассмотрим пример, который добавляет новую запись в нашу таблицу. код ниже показывает реализацию.
<?php $dbh = mysqli_connect('localhost', 'root', 'melody'); //connect to MySQL server if (!$dbh) die("Unable to connect to MySQL: " . mysqli_error()); //if connection failed output error message if (!mysqli_select_db($dbh,'my_personal_contacts')) die("Unable to select database: " . mysql_error()); //if selection fails output error message $sql_stmt = "INSERT INTO `my_contacts` (`full_names`,`gender`,`contact_no`,`email`,`city`,`country`)"; $sql_stmt .= " VALUES('Poseidon','Mail','541',' poseidon @ sea . oc ','Troy','Ithaca')"; $result = mysqli_query($dbh,$sql_stmt); //execute SQL statement if (!$result) die("Adding record failed: " . mysqli_error()); //output error message if query execution failed echo "Poseidon has been successfully added to your contacts list"; mysqli_close($dbh); //close the database connection ?>
Выполнив приведенный выше код, вы получите сообщение «Посейдон был успешно добавлен в ваш список контактов», вернитесь к примеру запроса выбора и снова получите свои контакты.
Посмотрите, добавлен ли «Посейдон» в ваш список.
Обновление записей Давайте теперь рассмотрим пример обновления записи в базе данных.
Предположим, что Посейдон сменил свой контактный номер и адрес электронной почты.
<?php $dbh = mysqli_connect('localhost', 'root', 'melody'); //connect to MySQL server if (!$dbh) die("Unable to connect to MySQL: " . mysqli_error()); //if connection failed output error message if (!mysqli_select_db($dbh,'my_personal_contacts')) die("Unable to select database: " . mysql_error()); //if selection fails output error message $sql_stmt = "UPDATE `my_contacts` SET `contact_no` = '785',`email` = ' poseidon @ ocean . oc '; //SQL select query $sql_stmt .= " WHERE `id` = 5"; $result = mysqli_query($dbh,$sql_stmt); //execute SQL statement if (!$result) die("Deleting record failed: " . mysqli_error()); //output error message if query execution failed echo "ID number 5 has been successfully updated"; mysqli_close($dbh); //close the database connection ?>
Удаление записей
Давайте теперь рассмотрим пример, который удаляет записи из базы данных. Предположим, что у Венеры есть запретительный судебный приказ против нас, и мы должны удалить ее контактную информацию из нашей база данных.
<?php $dbh = mysqli_connect('localhost', 'root', 'melody'); //connect to MySQL server if (!$dbh) die("Unable to connect to MySQL: " . mysqli_error()); //if connection failed output error message if (!mysqli_select_db($dbh,'my_personal_contacts')) die("Unable to select database: " . mysqli_error()); //if selection failes output error message $id = 4; //Venus's ID in the database $sql_stmt = "DELETE FROM `my_contacts` WHERE `id` = $id"; //SQL Delete query $result = mysqli_query($dbh,$sql_stmt); //execute SQL statement if (!$result) die("Deleting record failed: " . mysqli_error()); //output error message if query execution failed echo "ID number $id has been successfully deleted"; mysqli_close($dbh); //close the database connection ?>
Объект доступа к данным PHP PDO
PDO — это класс, который позволяет нам манипулировать различными механизмами баз данных, такими как MySQL, PostGres, MS SQL Server и т. д.
В приведенном ниже коде показан метод доступа к базе данных с использованием объекта PDO.
Примечание: приведенный ниже код предполагает знание языка SQL, массивов, обработки исключений и цикла foreach.
<?php try { $pdo = new PDO("mysql:host=localhost;dbname=my_personal_contacts", 'root', 'melody'); $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $pdo->exec('SET NAMES "utf8"'); $sql_stmt = "SELECT * FROM `my_contacts`"; $result = $pdo->query($sql_stmt); $result->setFetchMode(PDO::FETCH_ASSOC); $data = array(); foreach ($result as $row) { $data[] = $row; } print_r($data); } catch (PDOException $e) { echo $e->getMessage(); } ?>
ВОТ,
- «try{…catch…}» — блок обработки исключений.
- «$pdo = new PDO(»mysql…» создает экземпляр объекта PDO и передает драйверы базы данных, имена сервера и базы данных, идентификатор пользователя и пароль.
- «$pdo->setAtt…» устанавливает атрибуты режима ошибок PDO и режима исключений.
- «$pdo->exec('SET NA…» устанавливает формат кодирования
ODBC ODBC — это аббревиатура от Open Database Connectivity. Он имеет следующий базовый синтаксис.
<?php $conn = odbc_connect($dsn, $user_name, $password); ?>
ВОТ,
- «odbc_connect» — это встроенная функция PHP.
- «$dsn» — это имя источника данных ODBC.
- «$user_name» не является обязательным, он используется для имени пользователя ODBC.
- «$password» не является обязательным, он используется для пароля ODBC.
Используемый пример предполагает вас;
- Используете Windows OS
- Вы создали ссылку ODBC на Northwind. Microsoft Доступ к базе данных Northwind
Ниже приведен код реализации доступа к данным ODBC.
<?php $dbh = odbc_connect('northwind', '', ''); if (!$dbh) { exit("Connection Failed: " . $dbh); } $sql_stmt = "SELECT * FROM customers"; $result = odbc_exec($dbh, $sql_stmt); if (!$result) { exit("Error access records"); } while (odbc_fetch_row($result)) { $company_name = odbc_result($result, "CompanyName"); $contact_name = odbc_result($result, "ContactName"); echo "<b>Company Name (Contact Person):</b> $company_name ($contact_name) <br>"; } odbc_close($dbh); ?>
Итого
- MySQL это система управления реляционными базами данных с открытым исходным кодом, доступная на большинстве серверов веб-хостинга.
- PHP имеет богатую коллекцию встроенных функций, упрощающих работу с MySQL
- PDO — это аббревиатура объекта данных PHP; он используется для подключения к разным базам данных с использованием одного и того же объекта.
- PHP использует функцию odbc_connect для управления базами данных через ODBC.