Новости 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 Гость просматривают эту тему.
  • 8 Ответов
  • 3546 Просмотров
*

banditman

  • Захожу иногда
  • 113
  • 0 / 0
Всем здрасте!
Решил обновить старый сайт переехать с 1.5 на 3
Переезд с 1.5 на на 2.5 получился достаточно удачно, проблем не вызвал, но последующий перезд с 2.5 на 3 не задался, после обновления админка не работала и сайт вылетал в белый экран, пришлось через MySQL востанавливать таблицу БД. Сайт заработал но стили админки слетели, перерыл уже все что можно не помогает, перезаливал в ручную, изменений нет!
Подскажите может кто сталкивался?
Скриншот админки прилагаю!

лог сервера
Код
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: PHP Fatal error:  Uncaught exception 'RuntimeException' with message 'Unknown column 'header' in 'field list' SQL=SELECT `new_url`,`header`,`published`
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: FROM `j25_redirect_links`
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: WHERE `old_url` = 'http://stroy.it-master74.ru/jupgrade/' LIMIT 0, 1' in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/libraries/joomla/database/driver/mysqli.php:610
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: Stack trace:
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: #0 /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/libraries/joomla/database/driver.php(1239): JDatabaseDriverMysqli->execute()
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: #1 /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/plugins/system/redirect/redirect.php(86): JDatabaseDriver->loadObject()
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: #2 [internal function]: PlgSystemRedirect::handleError(Object(RuntimeException))
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215: #3 {main}
[Wed Jun 03 09:44:09 2015] [error] [client 94.24.224.142:58232] AH01215:   thrown in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/libraries/joomla/database/driver/mysqli.php on line 610
[Wed Jun 03 09:44:10 2015] [error] [client 94.24.224.142:58257] AH01215: PHP Notice:  Undefined property: LoginController::$input in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/administrator/components/com_login/controller.php on line 36
[Wed Jun 03 09:44:10 2015] [error] [client 94.24.224.142:58257] AH01215: PHP Fatal error:  Call to a member function set() on null in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/administrator/components/com_login/controller.php on line 36
[Wed Jun 03 11:45:48 2015] [error] [client 94.24.230.245:19292] AH01215: PHP Notice:  Undefined property: InstallerControllerUpdate::$input in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/administrator/components/com_installer/controllers/update.php on line 143, referer http://stroy.it-master74.ru/jupgrade/administrator/index.php
[Wed Jun 03 11:45:48 2015] [error] [client 94.24.230.245:19292] AH01215: PHP Fatal error:  Call to a member function getInt() on null in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/administrator/components/com_installer/controllers/update.php on line 143, referer http://stroy.it-master74.ru/jupgrade/administrator/index.php
[Wed Jun 03 11:45:50 2015] [error] [client 94.24.230.245:19438] AH01215: PHP Notice:  Undefined property: InstallerControllerUpdate::$input in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/administrator/components/com_installer/controllers/update.php on line 143, referer http://stroy.it-master74.ru/jupgrade/administrator/index.php
[Wed Jun 03 11:45:50 2015] [error] [client 94.24.230.245:19438] AH01215: PHP Fatal error:  Call to a member function getInt() on null in /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/administrator/components/com_installer/controllers/update.php on line 143, referer http://stroy.it-master74.ru/jupgrade/administrator/index.php
[Wed Jun 03 11:53:43 2015] [warn] [client 94.24.230.245:35590] AH01220: Timeout waiting for output from CGI script /usr/local/php-cgi/5.6/bin/php-cgi
[Wed Jun 03 11:53:43 2015] [error] [client 94.24.230.245:35590] Script timed out before returning headers: php-cgi
[Wed Jun 03 11:54:37 2015] [error] [client 94.24.230.245:39760] Invalid status line from script 'php-cgi': 1060 Duplicate column name 'cr
[Wed Jun 03 11:54:43 2015] [warn] [client 94.24.230.245:35590] AH01220: Timeout waiting for output from CGI script /usr/local/php-cgi/5.6/bin/php-cgi
[Wed Jun 03 11:56:32 2015] [warn] [client 94.24.230.245:42265] AH01220: Timeout waiting for output from CGI script /usr/local/php-cgi/5.6/bin/php-cgi
[Wed Jun 03 11:56:32 2015] [error] [client 94.24.230.245:42265] Script timed out before returning headers: php-cgi
[Wed Jun 03 12:14:30 2015] [info] [client 94.24.230.245:34347] AH00128: File does not exist: /home/v/vaicel/stroy.it-master74.ru/public_html/jupgrade/installation/index.php, referer http://stroy.it-master74.ru/jupgrade/administrator/index.php
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: PHP Fatal error:  Uncaught exception 'RuntimeException' with message 'Unknown column 'header' in 'field list' SQL=SELECT `new_url`,`header`,`published`
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: FROM `j25_redirect_links`
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: WHERE `old_url` = 'http://stroy.it-master74.ru/index.php/2010-11-30-20-11-47?catid=1074&id=1074:p-s-vn-ja-v-c-ljabins-i-bl-sti-p-r-shl-e-v-t-r' LIMIT 0, 1' in /home/v/vaicel/stroy.it-master74.ru/public_html/libraries/joomla/database/driver/mysqli.php:610
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: Stack trace:
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: #0 /home/v/vaicel/stroy.it-master74.ru/public_html/libraries/joomla/database/driver.php(1239): JDatabaseDriverMysqli->execute()
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: #1 /home/v/vaicel/stroy.it-master74.ru/public_html/plugins/system/redirect/redirect.php(86): JDatabaseDriver->loadObject()
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: #2 [internal function]: PlgSystemRedirect::handleError(Object(RuntimeException))
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215: #3 {main}
[Wed Jun 03 13:49:26 2015] [error] [client 66.249.64.79:49124] AH01215:   thrown in /home/v/vaicel/stroy.it-master74.ru/public_html/libraries/joomla/database/driver/mysqli.php on line 610
[Wed Jun 03 14:11:45 2015] [error] [client 77.222.97.127:15254] AH01215: PHP Fatal error:  Call to a member function get() on boolean in /home/v/vaicel/stroy.it-master74.ru/public_html/administrator/components/com_templates/views/templates/tmpl/default.php on line 101, referer http://stroy.it-master74.ru/administrator/index.php?option=com_templates
[Wed Jun 03 14:11:45 2015] [info] [client 77.222.97.127:15283] AH00128: File does not exist: /home/v/vaicel/stroy.it-master74.ru/public_html/favicon.ico, referer http://stroy.it-master74.ru/administrator/index.php?option=com_templates&view=templates
[Wed Jun 03 14:12:47 2015] [error] [client 77.222.97.127:17764] AH01215: PHP Fatal error:  Call to a member function get() on boolean in /home/v/vaicel/stroy.it-master74.ru/public_html/administrator/components/com_templates/views/templates/tmpl/default.php on line 101, referer http://stroy.it-master74.ru/administrator/index.php?option=com_templates&view=template&id=502&file=aG9tZQ
[Wed Jun 03 14:12:55 2015] [error] [client 77.222.97.127:17973] AH01215: PHP Fatal error:  Call to a member function get() on boolean in /home/v/vaicel/stroy.it-master74.ru/public_html/administrator/components/com_templates/views/templates/tmpl/default.php on line 101, referer http://stroy.it-master74.ru/administrator/index.php?option=com_templates&view=templates
« Последнее редактирование: 12.06.2015, 15:41:43 от b2z »
*

banditman

  • Захожу иногда
  • 113
  • 0 / 0
Вообщем всю эту бякость решить удалось только путем установки заново CMS, а потом вставки таблиц в новую базу (контакты, меню, контент и ....) и изменения их (старых таблиц) префикса! ^-^
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Думаю, именно так вам лучше и поступить - установить чистую 3.4 и перенести в ее базу таблицы со старого сайта. Но дело не только в таблицах. Вам придется менять все компоненты, плагины, модули - все, что ранее у вас стояло, не будет работать в новой версии.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

banditman

  • Захожу иногда
  • 113
  • 0 / 0
Не вижу в этом проблемы, так как при переезде с 1.5 на 2.5 все компоненты сторонние были удалены, вообщем все лишнее и старое удалено и будет заменено в 3))), а перенесены только таблицы связанные с контентом ;) Просто самое главное было сохранить все сттьи, а там их достаточно много, ручками  было не вариант.)
*

h.vitaly

  • Осваиваюсь на форуме
  • 37
  • 0 / 0
после обновления с Joomla 2.5.28 на 3.4.1 всю админку перекосило. что делать, куда рыть?
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
после обновления с Joomla 2.5.28 на 3.4.1 всю админку перекосило. что делать, куда рыть?
Создать новую теми и приложить ошибки / скрины.
*

banditman

  • Захожу иногда
  • 113
  • 0 / 0
после обновления с Joomla 2.5.28 на 3.4.1 всю админку перекосило. что делать, куда рыть?
Я решил эту проблему установкой чистой Joomla 3 и переносом БД нужных таблиц из перекошеной после обновления Joomla3 таблиц в пустую базу. Удалось сохранить весь контент, меню, контакты, категории и т.д.
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
*

banditman

  • Захожу иногда
  • 113
  • 0 / 0
Значит эту тему можно закрыть?
да
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться