Поиск на сайте - SQL запрос

  • 11 Ответов
  • 360 Просмотров

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

*

john.deff

  • Осваиваюсь на форуме
  • ***
  • 116
  • 0
Поиск на сайте - SQL запрос
« : 06.08.2016, 21: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

  • Профи
  • ********
  • 9653
  • 929
Re: Поиск на сайте - SQL запрос
« Ответ #1 : 07.08.2016, 00: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. если с условием не угадал, то из этого что-нибудь обязательно поможет :)
« Последнее редактирование: 07.08.2016, 00:11:44 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций

*

passer

  • Живу я здесь
  • ******
  • 874
  • 70
Re: Поиск на сайте - SQL запрос
« Ответ #2 : 07.08.2016, 01:50:25 »
Добавьте еще одно условие по type например.

*

john.deff

  • Осваиваюсь на форуме
  • ***
  • 116
  • 0
Re: Поиск на сайте - SQL запрос
« Ответ #3 : 07.08.2016, 03: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

  • Профи
  • ********
  • 9653
  • 929
Re: Поиск на сайте - SQL запрос
« Ответ #4 : 07.08.2016, 12:19:51 »
ну вопрос о правильном SQL запросе для получения нужного результата!
я уже вам вроде нужные варианты написал.

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

*

john.deff

  • Осваиваюсь на форуме
  • ***
  • 116
  • 0
Re: Поиск на сайте - SQL запрос
« Ответ #5 : 07.08.2016, 19: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

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

*

john.deff

  • Осваиваюсь на форуме
  • ***
  • 116
  • 0
Re: Поиск на сайте - SQL запрос
« Ответ #7 : 08.08.2016, 01:09:18 »
ну запрос по крайней мере похож на правильный. единственно что, если $value_phone у вас приходит извне, то так, как сейчас в запросе - это SQL injection. обратите на это внимание

а как лучше сделать, без SQL injection?
хочу знать..

*

dmitry_stas

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

*

zomby6888

  • Живу я здесь
  • ******
  • 1484
  • 167
Re: Поиск на сайте - SQL запрос
« Ответ #9 : 08.08.2016, 02:57:34 »
Разработчикам расширений стоило бы для начала почитать как писать безопасные расширения:

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

*

dmitry_stas

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

*

john.deff

  • Осваиваюсь на форуме
  • ***
  • 116
  • 0
Re: Поиск на сайте - SQL запрос
« Ответ #11 : 08.08.2016, 12:08:29 »
Разработчикам расширений стоило бы для начала почитать как писать безопасные расширения:

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

спасибо, изучаю!
хочу знать..