При работе с PDO важно правильно настроить соединение. Это делается с помощью атрибутов через метод setAttribute() или при создании объекта PDO.
Два самых важных атрибута:
PDO::ATTR_ERRMODE— режим обработки ошибок. Рекомендуется использоватьPDO::ERRMODE_EXCEPTION, чтобы при ошибках SQL выбрасывались исключения (Exception), которые можно ловить черезtry-catch.PDO::ATTR_DEFAULT_FETCH_MODE— формат данных по умолчанию. Удобно установитьPDO::FETCH_ASSOC, чтобы получать результаты как ассоциативные массивы, а не дублировать данные (индексы + ключи).
Пример: $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
- Модуль 1: Основы синтаксиса PHP
- Модуль 2: Переменные и типы данных
- Модуль 3: Операторы
- Модуль 4: Условные конструкции
- Модуль 5: Циклы
- Модуль 6: Массивы
- Индексированные массивы.
- Ассоциативные массивы.
- Многомерные массивы.
- Добавление элементов в массив.
- Удаление элементов из массива.
- Функция count().
- Функция array_push() и array_pop().
- Функция array_shift() и array_unshift().
- Функция array_merge().
- Функция array_slice().
- Функция array_splice().
- Функция in_array().
- Функция array_search().
- Функция array_keys() и array_values().
- Функция array_unique().
- Функция array_reverse().
- Сортировка: sort(), rsort().
- Сортировка: asort(), arsort().
- Сортировка: ksort(), krsort().
- Функция array_map().
- Функция array_filter().
- Функция array_reduce().
- Функция array_walk().
- Функция array_column().
- Деструктуризация массивов.
- Iterator интерфейс
- Модуль 7: Функции
- Объявление функций.
- Вызов функций.
- Параметры функций.
- Возврат значений return.
- Значения параметров по умолчанию.
- Передача по значению.
- Передача по ссылке.
- Переменное количество аргументов.
- Оператор распаковки ....
- Типизация параметров.
- Типизация возвращаемых значений.
- Nullable типы.
- Union типы (PHP 8).
- Именованные аргументы (PHP 8).
- Анонимные функции.
- Стрелочные функции.
- Замыкания и use.
- Рекурсивные функции.
- Глобальные переменные в функциях.
- Статические переменные в функциях.
- IteratorAggregate интерфейс
- Модуль 8: Работа со строками
- Одинарные и двойные кавычки.
- Экранирование символов.
- Heredoc и Nowdoc синтаксис.
- Функция strlen().
- Функция substr().
- Функция str_replace().
- Функция strpos() и strrpos().
- Функция explode() и implode().
- Функция trim(), ltrim(), rtrim().
- Функция strtolower() и strtoupper().
- Функция ucfirst() и ucwords().
- Функция str_repeat().
- Функция htmlspecialchars().
- Модуль 9: Суперглобальные переменные
- Модуль 10: Работа с формами
- Модуль 11: Работа с файлами
- Модуль 12: Дата и время
- Модуль 13: Регулярные выражения
- Модуль 14: Сессии и Cookie
- Модуль 15: Include и Require
- Модуль 16: Объектно-ориентированное программирование
- Модуль 17: Пространства имен
- Модуль 18: Обработка ошибок и исключений
- Модуль 19: Работа с JSON и XML
- Модуль 21: PDO - PHP Data Objects
- PDO атрибуты.
- Модуль 22: Composer и зависимости
- Модуль 23: cURL и HTTP запросы
- Модуль 24: REST API
- Модуль 25: Безопасность
- Модуль 28: Работа с изображениями
- Модуль 29: Отправка email
- Модуль 30: Паттерны проектирования
- Модуль 31: Тестирование
- Модуль 32: Продвинутые возможности PHP 8+
1. Атрибуты и значения
В левой колонке приведены фрагменты XML-разметки, связанные с информацией о пользователе. В правой колонке указано, является ли каждый фрагмент содержимым элемента или частью атрибута. Сопоставьте каждый фрагмент слева с соответствующей категорией справа. Обратите внимание, что в правой колонке есть повторяющиеся подписи — это сделано намеренно, поскольку в XML может быть несколько элементов и несколько атрибутов.
2. Включение исключений
Дополните фрагмент кода на PHP, который настраивает объект PDO для работы с базой данных. Необходимо установить атрибут, включающий режим генерации исключений при возникновении ошибок. Заполните пропуски в методе setAttribute() соответствующими константами. Обратите внимание, что в коде уже создано подключение к базе данных с использованием PDO.
<?php
$dsn = 'mysql:host=localhost;dbname=test';
$user = 'root';
$pass = '';
try {
$pdo = new PDO($dsn, $user, $pass);
// Включаем режим исключений для обработки ошибок
$pdo->setAttribute(input1S, input2S);
echo 'Режим исключений включен';
} catch (PDOException $e) {
echo 'Ошибка подключения: ' . $e->getMessage();
}
?>3. Опечатка в константе
В этом фрагменте кода, связанном с установкой атрибутов PDO, допущена ошибка в имени константы. Найдите и исправьте строку, в которой указана несуществующая константа PDO, чтобы код корректно установил режим обработки ошибок для подключения к базе данных.
<?php$dsn = 'mysql:host=localhost;dbname=test';$username = 'root';$password = ''; try { $pdo = new PDO($dsn, $username, $password); // Устанавливаем режим обработки ошибок $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_ERROR);} catch (PDOException $e) { echo 'Ошибка подключения: ' . $e->getMessage();}?>4. Настройка в конструкторе
Из предложенных строк соберите корректный PHP-скрипт, который создаёт подключение к базе данных MySQL через PDO, передавая в конструктор массив опций (четвёртый аргумент). Массив должен содержать три наиболее важных атрибута: режим обработки ошибок (исключения), режим выборки данных по умолчанию (ассоциативный массив) и отключение эмуляции подготовленных запросов. Порядок объявлений переменных $dsn, $username и $password строго фиксирован относительно друг друга. В решении не должно быть лишних строк, которые дублируют функциональность или выполняются после создания объекта.
<?php$dsn = 'mysql:host=localhost;dbname=test_db;charset=utf8mb4';$username = 'root';$password = '';$options = [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_EMULATE_PREPARES => false];$pdo = new PDO($dsn, $username, $password, $options);$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);$options = array(PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING);$pdo = new PDO($dsn, $username, $password);5. Диалог: Белый экран
В этом задании вы пообщаетесь с виртуальным ассистентом, который столкнулся с проблемой в PHP. У него ошибка в SQL-запросе при работе с PDO, но вместо сообщения об ошибке он видит только белый экран. Вам нужно помочь ему настроить отображение ошибок, объяснив, как использовать атрибут PDO::ATTR_ERRMODE со значением PDO::ERRMODE_EXCEPTION. Отвечайте на вопросы бота, вводя код или выбирая правильные варианты.