Новости Joomla

Метод registerListeners() в CMSPlugin в плагинах планируется удалить в Joomla 7.0

Метод registerListeners() в CMSPlugin в плагинах  планируется удалить в Joomla 7.0

👩‍💻 Метод registerListeners() в CMSPlugin в плагинах планируется удалить в Joomla 7.0.Этот метод регистрирует устаревшие слушатели событий в диспетчере, имитируя работу плагинов Joomla! 3.x и ниже для Joomla 4+. По умолчанию этот метод ищет все общедоступные методы, название которых начинается с on. Он регистрирует лямбда-функции (замыкания), которые пытаются преобразовать аргументы отправленного события в аргументы вызова метода и вызвать ваш метод on<Что-то>. Результат передаётся обратно событию в его аргумент result.Теперь этот слой совместимости с устаревшей Joomla 3 помечен к удалению в Joomla 7.0, которая должна выйти осенью 2027 года. Это означает, что те уникальные расширения от Joomla 2.5 / Joomla 3, которые ещё работали на Joomla 4-6 скорее всего окончательно перестанут работать на Joomla 7. Предполагается, что активные разработчики планомерно и постепенно избавляются от технического долга и обновляют свои расширения. @joomlafeed#joomla #разработка #php

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

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
Просмотров: 1062
Последний ответ 09.10.2016, 23:27:09
от voland