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

NetFix

  • Новичок
  • 4
  • 0 / 0
Здравствуйте, пишу компонент для организации обмена 1с с JoomShopping. По задумке работать он должен так:
Из 1с выгружается каталог, компонент(фронт энд часть) парсит его и раскладывает по таблицам: номенклатура, группы, характеристики, цены по видам цен, остатки по складам и прочее.

Есть таблица - посредник, которая содержит id номенклатуры 1с ,id продукта JoomShopping и настройки синхронизации информации из 1с, например изменять ли наименование, цену, остаток при обмене.

В бэк энд компонента видно группы и номенклатуру выгруженную из 1с в виде дерева(основное представление, список элементов), при клике по элементу(номенклатуре), открывается форма(представление элемента), где можно выбрать продукт JoomShopping, данные которого необходимо обновлять и настройки обновления(обновлять только цены, цены и остатки, наименование, описание и прочее).

То есть мне нужно получить(обновить, удалить) в этой форме данные из ряда таблиц, вопрос вот в чём, как правильно это сделать с точки зрения движка Joomla?

Насколько я понял, стандартный класс модели заточен для работы с одной таблицей и штатными методами такое сделать нельзя.

Какие конкретно методы в модели переопределять для этого? Для получения данных пока думаю переопределить метод getItem и сделать выборку в нём, но нужны ли мне для этого классы таблиц для каждой затрагиваемой таблице?
*

platonische

  • Давно я тут
  • 523
  • 2 / 1
  • Парусные экспедиции vk.com/tc670
Я не сильный советчик, но мне кажется вам нужно в модели определить новый метод и им прогнать необходимые действия по любым таблицам, главное сохранить структуру приложения не Joomla а JoomShopping.
Есть конечно минус этого решения - при смене структуре надо переделывать метод, но на решение влоб и понятия куда двигаться думаю пойдет.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Прописать условие для сохранения данных в БД

Автор semen1707

Ответов: 0
Просмотров: 456
Последний ответ 14.04.2021, 00:59:44
от semen1707
Модель для представления, которое показывает списки данных разных типов

Автор borro

Ответов: 27
Просмотров: 1215
Последний ответ 06.05.2020, 11:57:12
от Septdir
Связать две таблицы с БД для дальнейшего вывода данных с них

Автор golinejj

Ответов: 16
Просмотров: 1026
Последний ответ 06.02.2020, 15:40:58
от golinejj
Вывод данных из нескольких одинаковых таблиц

Автор Outpost

Ответов: 6
Просмотров: 801
Последний ответ 11.02.2019, 14:42:55
от passer
Вопрос по архитектуре данных

Автор platonische

Ответов: 11
Просмотров: 906
Последний ответ 16.11.2018, 22:56:03
от Septdir