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

goga_pgasovav

  • Захожу иногда
  • 444
  • 6 / 0
  • Внимательный джумловод
Всем привет!
Такой вот интересный вопрос возник.
Вывожу getDBO() запросом текст из поля. Как-то так:

Код
<?php
$db = &JFactory::getDBO();
array_reverse($db->setQuery("SELECT s.SubmissionId, v1.FieldValue AS Fullname, v2.FieldValue AS City, v3.FieldValue AS Message
FROM #__rsform_submissions s
LEFT JOIN #__rsform_submission_values v1 USING(SubmissionId)
LEFT JOIN #__rsform_submission_values v2 USING(SubmissionId)
LEFT JOIN #__rsform_submission_values v3 USING(SubmissionId)
WHERE
    s.UserId = 1
    AND v1.FormID = 3
    AND v1.FieldName = 'Fullname'
    AND v2.FormID = 3
    AND v2.FieldName = 'City'
    AND v3.FormID = 3
    AND v3.FieldName = 'Message'
ORDER BY s.SubmissionId DESC"));
$tstsmls = $db->loadAssocList();
foreach  ($tstsmls as $tstsml) { ?>
    <div class="testimonial">
        <div class="name"><?php echo $tstsml['Fullname']; ?> <span>(г.&nbsp;<?php echo $tstsml['City']; ?>)</span></div>
        <div class="message"><?php echo $tstsml['Message']; ?></div>
    </div>
<?php } ?>

И вот $tstsml['Message'] выводится в одну строку, без «символа перевода каретки» так называемого. Хотя текст хранится в нужном виде, с переносами.
Может кто знает, как вывести raw-текст? Т.е. без фильтрации, которая, судя по всему, тут применяется.
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
Хотя текст хранится в нужном виде, с переносами.
покажите пример что хранится и что выводится.
*

anatol81n

  • Захожу иногда
  • 82
  • 2 / 0
*

anatol81n

  • Захожу иногда
  • 82
  • 2 / 0
<div class="message"><?php echo $tstsml['Message']; ?></div>
вы выводите  $tstsml['Message'] в HTML потоке, и табы, переносы, пробелы более одного не выводятся. перенос строки в HTML делается тегом <br>
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
*

goga_pgasovav

  • Захожу иногда
  • 444
  • 6 / 0
  • Внимательный джумловод
Всем спасибо, кто пытался помочь!
Решение, предложенное ProtectYourSite, работает великолепно.  :D
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывести поля профиля Joomla

Автор romagromov

Ответов: 11
Просмотров: 1824
Последний ответ 28.04.2025, 10:25:44
от sivers
[Решено] Вывод значений из custom fields материала в модуле по имени поля

Автор goga_pgasovav

Ответов: 3
Просмотров: 1005
Последний ответ 30.12.2024, 13:22:11
от goga_pgasovav
Вывод дополнительного поля материала в модуле

Автор timofe

Ответов: 10
Просмотров: 2358
Последний ответ 06.10.2023, 14:02:24
от Mitriy
Добавление поля в форму регистрации

Автор Robert24

Ответов: 3
Просмотров: 866
Последний ответ 10.10.2022, 23:35:04
от Robert24
Тип поля формы Select sql, как заполнить его через функцию php?

Автор GuDeVic

Ответов: 13
Просмотров: 1429
Последний ответ 07.10.2022, 12:25:45
от fsv