Новости Joomla

Вышли релизы Joomla 6.0.3 и Joomla 5.4.3

Релиз Joomla 6.0.3 и Joomla 5.4.3

Проект Joomla рад сообщить о выпуске Joomla 6.0.3 и Joomla 5.4.3. Это релиз исправлений ошибок и улучшений для серии Joomla 6.0 и Joomla 5.4.

👩‍💻 События плагинов и порядок их срабатывания при работе с пользовательскими полями Joomla и использовании FieldsHelper.

👩‍💻 События плагинов и порядок их срабатывания при работе с пользовательскими полями Joomla и использовании FieldsHelper.

В процессе работы с Joomla бывает необходимо работать с пользовательским интерфейсом более тонко, чем обычно. Все формы Joomla состоят из стандартных полей, содержанием, стилем отображения, состоянием (включено/выключено, доступно для редактирования или нет и т.д.) можно управлять с помощью плагинов. Да и для нестандартных проектов хорошей практикой является создание одного системного или нескольких плагинов групп "под проект", в которых храниться весь "нестандарт".

В этой статье описаны все триггеры, которые вызываются через Event Dispatcher из administrator/components/com_fields/src/Helper/FieldsHelper.php, с привязкой к жизненному циклу (порядку этапов работы запроса), аргументам, изменяемым данным и дальнейшему распространению по Joomla. Это поможет вам работать с Joomla свободнее и не опасаясь при этом потерять изменения при очередном обновлении движка.

Подходы, описанные в статье, полезны в тех случаях, когда вы работаете с данными в com_fields - механизме создания и редактирования пользовательских полей ядра Joomla и при использовании FieldsHelper. Многие сторонние компоненты не используют эту возможность, поэтому данная статья будет полезна лишь частично.

🏆 Открыто голосование за Joomla в премии CMS Critic People’s Choice Awards 2025

🏆 Открыто голосование за Joomla в  премии CMS Critic People’s Choice Awards 2025

🗓 Голосование продлится до 27 февраля 2026 года.

👩‍💻 Проголосовать! 👩‍💻

Номинации, в которых можно проголосовать за Joomla:
⭐️ Best Free CMS
⭐️ Best Open Source CMS
⭐️ Best Enterprise CMS

Также в номинации Best e-Commerce Solution участвуют компоненты интернет-магазинов для Joomla:
⭐️ HikaShop
⭐️ Virtuemart

В номинации Best Website Builder оказались:
⭐️ YooTheme
⭐️ SP Page Builder

Что такое CMS Critic Awards?
С 2012 года премия CMS Critic Awards занимает особое место в сообществе систем управления контентом (CMS). Это единственный в своем роде сайт, который составляет рейтинг системы управления контентом и связанных с ними решений на рынке — от малого до крупного и подчеркивает их инновации и услуги.

Каждый год награда CMS Critic Awards присуждается одному победителю в различных отраслевых категориях, таких как: «Лучшая облачная CMS», «Лучший DXP», «Лучшая Headless CMS и других. Затем результаты оглашаются через СМИ вместе с выбором редакции CMS Critic.
В этом году премия вернулась к своим традициям и только TOP-5 движков по количеству номинаций попали в 2-й этап - голосование.

@joomlafeed

0 Пользователей и 1 Гость просматривают эту тему.
  • 13 Ответов
  • 961 Просмотров
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Задача для экспертов в MySQL. )

у нас есть  _users,  _user_usergroup_map, _usergroups ( надо ли? )

Это мы можем  -
SELECT  _users.username FROM  _users,  _user_usergroup_map
        WHERE  _users.id =  _user_usergroup_map.user_id
        AND  _user_usergroup_map.group_id = 7

Получаем  список пользователей входящих в группу с id = 7 , т.е. Administrator.

Есть переменная $user_id - текущий пользователь.

Что надо? Сущий пустяк! )

IF текущий пользователь ($user_id) входит в группу Administrator THEN вывести всех из _users
ELSE  вывести только пользователей входящих в группу Administrator

Где зарыта собака? )
Все нужно сделать в одном запросе, без php. )
Одна переменная в одном запросе.
Реально ли это?

Если реально,  называйте стоимость работ! )
« Последнее редактирование: 20.12.2016, 00:17:56 от pirks »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #1 : 20.12.2016, 06:38:41 »
двумя запросами через проверку:
if (JFactory::getUser($user_id)->gid != 7)
{
    // тут запрос на полный список, без уссловий
} else {
   // тут запрос только админов (выше вроде корректно)
}
« Последнее редактирование: 20.12.2016, 06:47:26 от AlekVolsk »
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #2 : 20.12.2016, 08:42:25 »
AlekVolsk, спасибо, но это я понимаю. Так и сделал бы. )
Если бы не одно условие - в одном запросе выяснить, какой группе принадлежит текущий user и сделать соответствующий select.
Тут надо использовать вложенные SELECT, CASE, IF и т.д.
А может быть и переменные MySQL.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #3 : 20.12.2016, 09:13:10 »
так не получится: вы можете использовать вложенный селект как условие выборки, но вы не можете отказаться от условия вообще, если результат вложенного селекта не соответствует требуемому условию

как вариант, можно попробовать использовать хранимые процедуры, но это опять же - уже не один запрос
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #4 : 20.12.2016, 22:27:31 »
Меня все таки гложат сомнения, что это нельзя сделать в одном запросе. )
В этот раз я выкрутился, проблему решил, но такая задача может возникнуть   опять и хотелось бы понять - реализуемо это или нет.
Как-то давно решал подобное с помощью алиасов. )
Но для для сложных SQL запросов нужно иметь светлую и пустую голову. )
На днях все-таки попробую . )
 
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #5 : 20.12.2016, 23:40:19 »
первое что пришло в голову, вариант с IN и IF

Код: sql
SELECT * FROM `#__users` WHERE id IN (SELECT user_id FROM `#__user_usergroup_map` WHERE group_id=7) OR id > IF((SELECT count(*) FROM `#__user_usergroup_map` WHERE group_id=7 AND user_id= $user_id ) > 0, 0, 2147483647)

P.S. или надо было сначала озвучить стоимость? :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #6 : 21.12.2016, 09:17:47 »
P.S. или надо было сначала озвучить стоимость? :)

Сейчас проверю!

P.S.  $2? Не? ))
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #7 : 22.12.2016, 14:01:11 »
запрос правильный? :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #8 : 22.12.2016, 14:09:56 »
запрос правильный? :)
Пока  с наскоку не пошел. ) Но тут еще может проявляться кривость моих рук. Поэтому пока ответа на вопрос нет. )
В HeiDiSQL не тестировался?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #9 : 22.12.2016, 14:20:18 »
нет. в phpMyAdmin тестировался
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #10 : 23.12.2016, 21:14:25 »
dmitry_stas Спасибо!
Все работает!  :D
Яндекс- кошелек давай - $2 твои!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #11 : 23.12.2016, 21:38:27 »
ахаха :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #12 : 23.12.2016, 21:56:52 »
Это  круто!
Особенно - вот это
Код
id > IF((SELECT count(*) FROM `#__user_usergroup_map` WHERE group_id=7 AND user_id= $user_id ) > 0, 0, 2147483647)

 
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #13 : 23.12.2016, 22:06:36 »
ну надо ж было как то обдурить, подзапрос выполнить :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

База данных MySQL периодически не отвечает

Автор nightbeast

Ответов: 10
Просмотров: 1185
Последний ответ 09.10.2016, 23:27:09
от voland