Новости Joomla

👩‍💻 WT CDEK library v.1.3.0 - обновление PHP SDK для Joomla + CDEK.

👩‍💻 WT CDEK library v.1.3.0 - обновление PHP SDK для Joomla + CDEK.

Небольшая нативная PHP Joomla библиотека для работы с API v.2 службы доставки CDEK. Библиотека представляет собой клиент для авторизации в CDEK API по OAuth, работы с некоторыми методами API: получения ряда данных и расчета стоимости доставки. Поддерживается Joomla 4.2.7 и выше.

В пакет входят:
- библиотека Webtolk/Cdekapi
- системный плагин System - WT Cdek для хранения настроек и AJAX-интеграций
- task-плагин Task - Update WT Cdek data для обновления локальных копий справочников CDEK по расписанию
- web asset с официальным JavaScript-виджетом СДЭК

👉 v.1.3.0. Что нового?
- Полный рефакторинг библиотеки. Библиотека переработана в entity-based API с фасадом Cdek и отдельным слоем запросов. Обратная совместимость не нарушена, поэтому версия библиотеки - 1.3.0.
- Добавлена поддержка новых разделов API СДЭК. Добавлена поддержка новых разделов API СДЭК: webhooks, prealert, печатные формы, payment, passport, reverse, intakes и других сущностей.
- Улучшена интеграция с Joomla.
Улучшена интеграция с Joomla: installer script для layouts, новые поля Joomla Form для тарифов и обновлённые js виджета CDEK.
- документация библиотеки. Все методы библиотеки подробно описаны, а так же текст документации собран в отдельной папке в git репозитории и будет опубликован на сайте.

Библиотека эта нужна для разработчиков, создающих свои расширения для интеграции Joomla и курьерской службы CDEK.

Страница расширения
GitHub расширения

@joomlafeed

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

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Поиск на сайте - SQL запрос
« : 06.08.2016, 19:27:01 »
есть две таблицы #__objects и #__secret
Пример данных в таблице #__objects
--------------
| id | name |
--------------
| 1 | имя 1 |
| 2 | имя 2 |
| 3 | имя 3 |
|....| имя...|
--------------

Пример данных в таблице #__secret
---------------------------
| id | id_objects |  type  | number |
---------------------------
| 1 |       1        | object | 345677 |
| 2 |       1        | phone | 314677 |
| 3 |       1        | phone | 355572 |
| 4 |       2        | object | 263478 |
| 5 |       3        | object | 764382 |
----------------------------

Вопрос!

как нам получить вывод данных
если:
Код: php-brief
$value_phone = "677";
$q->select(array('a.*', 'b.*'))
            ->from('#__objects AS a')
            ->join('INNER', '#__secret AS b ON (a.id = b.id_objects)')
            ->where('b.number LIKE "%'.$value_phone.'%"')

проблема в том, что моё условие выборки даёт 2 объекта!
а мне надо один объект! в данном случае с id = 1 в таблице #__objects

надеюсь понятно объяснил  ^-^
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #1 : 06.08.2016, 22:07:42 »
Вопрос!

как нам получить вывод данных
вывод данных - это echo. или var_dump. или еще print_r например есть. а вопрос в чем? :)

проблема в том, что моё условие выборки даёт 2 объекта!
проблема в том, что нигрена не понятно :) как оно может дать 1, если по вашему условию LIKE "%'.$value_phone.'%" 2 подходит - id=1 и id=2? а почему именно id=1? вы или в условие type="object" добавьте, или если я не угадал, то объясните нормально

P.S. кстати помимо INNER JOIN есть еще LEFT JOIN. и также есть еще GROUP BY. если с условием не угадал, то из этого что-нибудь обязательно поможет :)
« Последнее редактирование: 06.08.2016, 22:11:44 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

passer

  • Завсегдатай
  • 1013
  • 75 / 3
Re: Поиск на сайте - SQL запрос
« Ответ #2 : 06.08.2016, 23:50:25 »
Добавьте еще одно условие по type например.
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #3 : 07.08.2016, 01:56:38 »
вывод данных - это echo. или var_dump. или еще print_r например есть. а вопрос в чем? :)
проблема в том, что нигрена не понятно :) как оно может дать 1, если по вашему условию LIKE "%'.$value_phone.'%" 2 подходит - id=1 и id=2? а почему именно id=1? вы или в условие type="object" добавьте, или если я не угадал, то объясните нормально

P.S. кстати помимо INNER JOIN есть еще LEFT JOIN. и также есть еще GROUP BY. если с условием не угадал, то из этого что-нибудь обязательно поможет :)

ну вопрос о правильном SQL запросе для получения нужного результата!
Если у нас есть два совпадения в таблице #__secret, то необходимо вывести один объект к которому они, эти совпадения принадлежат
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #4 : 07.08.2016, 10:19:51 »
ну вопрос о правильном SQL запросе для получения нужного результата!
я уже вам вроде нужные варианты написал.

Если у нас есть два совпадения в таблице #__secret, то необходимо вывести один объект к которому они, эти совпадения принадлежат
если при этом все равно, какая строка присоединится из #__secret, то используйте группировку (GROUP BY) по id из первой таблицы. если не все равно - добавляйте WHERE b.type=...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #5 : 07.08.2016, 17:51:52 »
я уже вам вроде нужные варианты написал.
если при этом все равно, какая строка присоединится из #__secret, то используйте группировку (GROUP BY) по id из первой таблицы. если не все равно - добавляйте WHERE b.type=...

сделал
Код: php-brief
$value_phone = "677";
$q->select(array('a.*', 'b.*'))
            ->from('#__objects AS a')
            ->join('INNER', '#__secret AS b ON (a.id = b.id_objects)')
            ->where('b.number LIKE "%'.$value_phone.'%"')
            ->group('b.id_objects'); // добавил группировку!

теперь работает как надо! Спасибо!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #6 : 07.08.2016, 19:32:34 »
ну запрос по крайней мере похож на правильный. единственно что, если $value_phone у вас приходит извне, то так, как сейчас в запросе - это SQL injection. обратите на это внимание
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #7 : 07.08.2016, 23:09:18 »
ну запрос по крайней мере похож на правильный. единственно что, если $value_phone у вас приходит извне, то так, как сейчас в запросе - это SQL injection. обратите на это внимание

а как лучше сделать, без SQL injection?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #8 : 07.08.2016, 23:54:08 »
а вы сами то как считаете, как лучше - с ней или без нее? вы понимаете что такое SQL injection? лучше да, без возможности SQL инъекции.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Поиск на сайте - SQL запрос
« Ответ #9 : 08.08.2016, 00:57:34 »
Разработчикам расширений стоило бы для начала почитать как писать безопасные расширения:

https://cmscafe.ru/razrabotka/547-sozdaem-bezopasnye-rasshireniya-dlya-joomla
интернет-блог: http://websiteprog.ru
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #10 : 08.08.2016, 08:09:52 »
ну да, как то так... там даже с LIKE пример есть.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #11 : 08.08.2016, 10:08:29 »
Разработчикам расширений стоило бы для начала почитать как писать безопасные расширения:

https://cmscafe.ru/razrabotka/547-sozdaem-bezopasnye-rasshireniya-dlya-joomla

спасибо, изучаю!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

SQL запрос с JOIN LEFT use IN

Автор platonische

Ответов: 12
Просмотров: 907
Последний ответ 20.10.2017, 10:57:08
от platonische
SQL запрос в оператором OR в where

Автор platonische

Ответов: 18
Просмотров: 1438
Последний ответ 30.11.2016, 18:26:47
от zomby6888
Sql запрос JOIN и LIMIT

Автор platonische

Ответов: 6
Просмотров: 1412
Последний ответ 06.04.2016, 14:31:09
от zomby6888
Внешняя БД и вывод в определенное место на сайте

Автор Pavel8289

Ответов: 5
Просмотров: 1160
Последний ответ 12.12.2015, 03:26:42
от Филипп Сорокин
Стандартный поиск по собственному компоненту

Автор platonische

Ответов: 1
Просмотров: 959
Последний ответ 03.11.2015, 20:41:25
от voland