Новости Joomla

Совет по Joomla: $db->getQuery(true) стал устаревшим

Совет по Joomla: $db->getQuery(true) стал устаревшим

👩‍💻 Совет по Joomla: $db->getQuery(true) стал устаревшим.Раньше при создании запросов в базу данных мы всегда получали объект запроса с помощью метода

getQuery(). Если передавался параметр
$new =
true, то получали новый запрос. Если без - последний.

use Joomla\CMS\Factory;$db = Factory::getContainer()->get('DatabaseDriver');$query = $db->getQuery(new: true);// и строим запрос
Под капот Joomla 4 вошёл Joomla Framework (PHP фреймворк а-ля Laravel, Yii и т.д.), а для Joomla 5 он обновился - версия 3.4.1 вышла 6 октября 2023г. В методе фреймворка есть примечание о том, что параметр
$new, который передавался в метод
getQuery() помечен как устаревший и будет удалён в версии фреймворка 4.0.
The parameter $new is deprecated and will be removed in 4.0, use %s::createQuery() instead.В Joomla 4 версия Joomla Framework была 2.x., в Joomla 5 - 3.x. Поэтому есть предположение, что с выходом Joomla 6 обновится и версия фреймворка - станет 4.0. Поэтому для получения объекта для новых запросов следует использовать метод
createQuery(). Он уже представлен в ядре и широко используется. При этом метод
getQuery() останется, но, скорее всего, будет выполнять функцию только геттера - получения текущего запроса.
@joomlafeed#joomla #php #разработка

0 Пользователей и 1 Гость просматривают эту тему.
  • 0 Ответов
  • 32857 Просмотров
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Данная ошибка возникает, если вы пытаетесь восстановить базу данных на MySQL 4.0.x или ниже из дампа сделанного на версии MySQL 4.1 и выше. Т.е. дамп вы делали на MySQL 4.1 или выше, а восстанавливаете на более старой (младше чем 4.1).

Для решения этой проблемы, необходимо при создании дампа базы выберите режим совместимости с MYSQL40 (в phpMyAdmin такой параметр точно есть).

Если дамп уже сделан, замените в нем ENGINE=MyISAM на TYPE=MyISAM и удалите все фрагменты вроде DEFAULT CHARSET=latin1 (вместо latin1 могут быть указаны другие кодировки, например cp1251).
« Последнее редактирование: 11.07.2007, 13:26:12 от smart »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Что означает ошибка Failed opening required 'includes/joomla.php'?

Автор smart

Ответов: 0
Просмотров: 114967
Последний ответ 03.07.2008, 12:04:06
от smart
Что означает ошибка Failed opening required '/includes/version.php'?

Автор smart

Ответов: 0
Просмотров: 80892
Последний ответ 17.06.2008, 22:55:39
от smart
Ошибка MySQL: "Got error 134 from storage engine..."

Автор smart

Ответов: 0
Просмотров: 36093
Последний ответ 11.07.2007, 13:22:22
от smart
Что означает ошибка: "Only variables can be passed by reference in ..."

Автор smart

Ответов: 0
Просмотров: 53118
Последний ответ 16.06.2007, 12:27:54
от smart
Что означает ошибка "Not unique table/alias..."

Автор smart

Ответов: 0
Просмотров: 33266
Последний ответ 30.05.2007, 17:03:48
от smart