Новости Joomla

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

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
Просмотров: 685
Последний ответ 20.10.2017, 10:57:08
от platonische
SQL запрос в оператором OR в where

Автор platonische

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

Автор platonische

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

Автор Pavel8289

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

Автор platonische

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