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

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Здравствуйте! )
Проблема такая:
На Joomla!3 Сделал сайт. Делал сразу на хостинге. Всё работало отлично до недавних пор. Пару дней назад зашел на свой сайт и мне пишет: "Error displaying the error page: Application Instantiation Error". Данное сообщение выходит и при входе на сайт и при входе в панель управления. Не могу понять с чего это. Перед этим я пытался вставить на сайт погодный информер от Гисметео, но навряд-ли это имеет значение, поскольку я это делал через создание новой статьи и последующим вставкой его в виде модуля в отдельной позиции (встало криво).
Как сделать, чтобы опять всё заработало?

P.S. В создании сайтов я лол. Это мой первый опыт в этом деле. Поэтому буду рад более-менее подробным объяснениям и советам, а также ссылкам на материалы, которые помогут мне решить мою проблему. Спасибо.
« Последнее редактирование: 26.06.2013, 11:57:18 от b2z »
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Сначала спросите у хостера не делал ли он что-то на хостинге.
Особенно в плане работы базы данных MySQL
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Такой вопрос отсылал, но ответа не получил...
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Наберите в Поиске на форуме фразу "Application Instantiation Error" и почитайте варианты.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Это я тоже сделал - ничего не подошло, поэтому и решил создать новую тему.  
« Последнее редактирование: 18.06.2013, 09:35:18 от VicNG »
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Поиск в Google по вашим данным так же говорит о том, что скорее всего проблемы с базой данных, в частности с правами пользователя базы.
Так что копайте в этом направлении.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
в файле configuration.php в полях

public $user = '****';
public $password = ****'';
public $db = ****'

тоже всё нормально...
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Кстати, в configurstion.php  в поле "public $host" пишет   "= 'localhost';"

public $host = 'localhost';

Это нормально? При условии, что сайт находиться на хосте и в локальной версии никогда не делался?
*

SDKiller

  • Живу я здесь
  • 2706
  • 329 / 5
  • ...ergo sum
public $host = 'localhost';
Это нормально? При условии, что сайт находиться на хосте и в локальной версии никогда не делался?

Зависит от хостинга - где-то мускул на localhost, где-то может быть на отдельном сервере.
В таком случае вам у вас в данных аккаунта должна быть эта информация, что-то вроде

Цитировать
сервер:       mysql38.1gb.ru
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Вот ещё. При проверке базы данных MySQL выдает

"Error    : Table '****' doesn't exist
status   : Operation failed".

И это во всех строчках.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #10 : 18.06.2013, 09:52:33 »
В "Управление привилегиями пользователей" стоит галочка на "ALL PRIVILEGES".
*

SDKiller

  • Живу я здесь
  • 2706
  • 329 / 5
  • ...ergo sum
Re: Error displaying the error page: Application Instantiation Error
« Ответ #11 : 18.06.2013, 10:00:32 »
Так
"Error    : Table '****' doesn't exist

Так у вас реально звёздочки в конфиге?
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #12 : 18.06.2013, 10:11:13 »
Так
Так у вас реально звёздочки в конфиге?
Хотел задать такой же вопрос
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #13 : 18.06.2013, 10:16:30 »
Не ) это я хотел обозначить, что во всех строчках так )
*

SDKiller

  • Живу я здесь
  • 2706
  • 329 / 5
  • ...ergo sum
Re: Error displaying the error page: Application Instantiation Error
« Ответ #14 : 18.06.2013, 10:21:50 »
Ну зайдите в phpMyAdmin да посмотрите - существует вообще база и таблицы в ней
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #15 : 18.06.2013, 10:22:05 »
Попросите у хостера старый бэкап базы данных и залейте его.
У правильного хостера такой бэкап имеется.
Или сами гляньте свою файловую структуру и поищите файл бэкапа в папках типа backup
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #16 : 18.06.2013, 10:31:49 »
В phpMyAdmin база существует. Вроде нормально всё. Файла бэкапа не нашел, хостер до сих пор молчит.
*

SK

  • Живу я здесь
  • 2155
  • 164 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #17 : 18.06.2013, 10:55:32 »
В phpMyAdmin база существует. Вроде нормально всё. Файла бэкапа не нашел, хостер до сих пор молчит.
Но как же всё нормально, если вы написали
Цитировать
"Error    : Table '****' doesn't exist
Что за таблица?
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #18 : 19.06.2013, 09:45:13 »
Но как же всё нормально, если вы написали Что за таблица?

Это в базе данных MySQL.
*

VicNG

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Error displaying the error page: Application Instantiation Error
« Ответ #19 : 26.06.2013, 10:29:26 »
Всем спасибо, всё разрешилось! ) Хостер по запросу сделал бэкап.)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] Вывод значений из custom fields материала в модуле по имени поля

Автор goga_pgasovav

Ответов: 3
Просмотров: 1001
Последний ответ 30.12.2024, 13:22:11
от goga_pgasovav
[Решено] Получить category description image в index.php шаблона

Автор goga_pgasovav

Ответов: 6
Просмотров: 1051
Последний ответ 12.07.2024, 17:06:14
от goga_pgasovav
[Решено] Перестали работать переходы по меню сайта

Автор AlexP750

Ответов: 12
Просмотров: 1664
Последний ответ 06.02.2024, 12:42:26
от AlexP750
[Решено] Ссылка на домен и текущий шаблон в блоге категории

Автор goga_pgasovav

Ответов: 2
Просмотров: 743
Последний ответ 06.03.2023, 16:30:23
от goga_pgasovav
[Решено] Не добавляется CSS-класс страницы

Автор Strelok760

Ответов: 16
Просмотров: 1726
Последний ответ 02.03.2023, 16:14:47
от Танита Сар