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

leeryfox

  • Новичок
  • 5
  • 0 / 0
Всем ДД.
Есть задача:
Поле SQL. Для поля требуется пара value  text.
Я хочу вставить в материал поле SQL, которое будет выводить данные из профиля пользователя.

Зачем надо - чтобы менять только в профиле, и тогда автоматически будет меняться в документах.
Но столкнулась с тем, что в базе пишется не кириллица а юникод, пример : "\u0417\u0434\u043e\u0440\u043e\u0432".

Вставляю запрос  sql вывода данных и получаю при заполнении полей-юникод, причем если его выбрать , то тоже будет отображаться юникод (.
(SELECT profile_value  as text , user_id as value  FROM joo_user_profiles WHERE profile_key = 'profile.favoritebook')

Как решить вопрос пока не поняла. Надо чтото добавить в вывод sql ? collate не прокатывает. Если может у кого идеи ? Буду благодарна.
*

sivers

  • Живу я здесь
  • 2587
  • 359 / 0
Но столкнулась с тем, что в базе пишется не кириллица а юникод, пример : "\u0417\u0434\u043e\u0440\u043e\u0432".
А страницы у вас в какой кодировке отображаются? win-1251?

Желательно, чтоб кодировка страниц совпадала с кодировкой БД. Тогда таких проблем не будет.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
А страницы у вас в какой кодировке отображаются? win-1251?

Желательно, чтоб кодировка страниц совпадала с кодировкой БД. Тогда таких проблем не будет.
Страницы отображает же jooomla . Она нормально себя конвертируют  .
Т, е. Я зашла в админке в профиль пользователя, написала на русском "Здоров", в профиле отображается на русском, на сайте на русском. А вот в базе "\u0417\u0434\u043e\u0440\u043e\u0432". Делая напрямую запрос к базе в поле sql  получаю "\u0417\u0434\u043e\u0440\u043e\u0432".
Скорее всего выводит значение поля как стринг по умолчанию чтоли..картинка вывода поля в админке:
https://drive.google.com/file/d/1goPu_xIOew3WR_YDo-k8CXf6zbQjE69q/view?usp=sharing
 и что в базе имеем
https://drive.google.com/file/d/1sVUeqvsv-UapJeClc80-Sk18mLgBqpEN/view?usp=sharing
« Последнее редактирование: 28.02.2023, 12:21:45 от leeryfox »
*

sivers

  • Живу я здесь
  • 2587
  • 359 / 0
какая кодировка для таблицы выбрана? как именно читаете из БД? через классы Joomla или через mysqli / pdo?
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
какая кодировка для таблицы выбрана? как именно читаете из БД? через классы Joomla или через mysqli / pdo?
в базе "Сопоставление кодировки соединения: utf8_general_ci"
Читается через поле sql - запрос в первом сообщении.
Или что имеется ввиду ?
запрос в поле sqlhttps://drive.google.com/file/d/1anPPZez-U5IMa9sWifL6GfVuHgoVGCqh/view?usp=sharing
*

sivers

  • Живу я здесь
  • 2587
  • 359 / 0
Посмотртел. Все нормально там. Это не уникод, а жсон.
После того, как прочитаете строку из той таблицы, надо сделать ей жсон-распаковку (не удаляя двойные кавычки):
Код

// Допустим прочитали строку из БД в $code, далее
$text = json_decode($code);
echo $text;

На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
Посмотртел. Все нормально там. Это не уникод, а жсон.
После того, как прочитаете строку из той таблицы, надо сделать ей жсон-распаковку (не удаляя двойные кавычки):
Код

// Допустим прочитали строку из БД в $code, далее
$text = json_decode($code);
echo $text;

Так в поле только sql  запрос можно. И это поле потом используется отдельно в настройках материала. Там не подставить что-то другое кроме sql :(.
А Php  код разве можно вставить в Контент - материал ?
я думала только джава скрипт и HTML...
*

sivers

  • Живу я здесь
  • 2587
  • 359 / 0
Так в поле только sql  запрос можно
а, ну это да. там можно вот так (пример):

Код
SELECT JSON_UNQUOTE(`profile_value`->'$') AS `text`
FROM `bl1li_user_profiles`
WHERE `profile_key` = 'profile.address1'
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

sivers

  • Живу я здесь
  • 2587
  • 359 / 0
В условие выборки (WHERE) желательно поставить условие, которое будет выбирать только json-поля. иначе ошибка в запросе будет
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

leeryfox

  • Новичок
  • 5
  • 0 / 0
Все заработало! СПАСИБО! :-* :D *DRINK*
*

sivers

  • Живу я здесь
  • 2587
  • 359 / 0
На здоровье
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка Отсутствует поле "itemReviewed

Автор Zegeberg

Ответов: 3
Просмотров: 997
Последний ответ 24.10.2024, 12:38:24
от Zegeberg
Как вывести блог категории в материале?

Автор x1

Ответов: 0
Просмотров: 619
Последний ответ 22.10.2024, 20:11:11
от x1
Если сайт выключен как вывести сообщение и картинку?

Автор Alexs44

Ответов: 1
Просмотров: 705
Последний ответ 03.09.2024, 16:24:02
от sivers
Поле "сообщение" RSContact высотой в одну строку

Автор antipod

Ответов: 1
Просмотров: 699
Последний ответ 08.07.2024, 21:30:40
от Vastriet
Pagination вывести jnext jprev

Автор brigadier

Ответов: 2
Просмотров: 697
Последний ответ 05.11.2023, 11:22:33
от brigadier