WedX - журнал о программировании и компьютерных науках

Sql показывает 10 результатов, где type = x и 10 результатов, где type = y

Можно ли получить эти два утверждения в один запрос?

   $q = mysqli_query($con,"SELECT * FROM angebote where (city = '".$_POST['search']."' OR plz = '".$_POST['search']."') AND art = 'biete' ORDER BY id DESC LIMIT 18");

   $p = mysqli_query($con,"SELECT * FROM angebote where (city = '".$_POST['search']."' OR plz = '".$_POST['search']."') AND art = 'suche' ORDER BY id DESC LIMIT 18");

не работает с UNION или UNION ALL

ТАК, когда я пытался

    $q = mysqli_query($con,"SELECT * FROM angebote where (city = '".$_POST['search']."' OR plz = '".$_POST['search']."') AND art = 'biete' ORDER BY id DESC LIMIT 10 UNION
                SELECT * FROM angebote where (city = '".$_POST['search']."' OR plz = '".$_POST['search']."') AND art = 'biete' ORDER BY id DESC LIMIT 10");

он говорит Предупреждение: mysqli_fetch_assoc() ожидает, что параметр 1 будет mysqli_result, логическим значением, заданным в C:.....

07.04.2016

  • Союз должен работать исправно. Что вы пробовали в качестве профсоюза? 07.04.2016
  • ну, я просто поместил их в один запрос, разделенный ОБЪЕДИНЕНИЕМ, например $q = mysqli_query($con,SELECT * FROM angebote, где (city = '.$_POST['search'].' ИЛИ ​​plz = '.$_POST['search '].') AND art = 'biete' ORDER BY id DESC LIMIT 18 UNION SELECT......); 07.04.2016
  • а какая была ошибка? Вы должны показать, что вы пробовали до сих пор 07.04.2016
  • да, просто используйте ИЛИ между art. 07.04.2016

Ответы:


1

UNION отлично работает здесь:

$q = mysqli_query($con, "
    SELECT * FROM 
    (SELECT
      * 
    FROM 
      angebote
    WHERE 
      (city = '".$_POST['search']."' OR plz = '".$_POST['search']."') AND 
      (art = 'biete')
    ORDER BY id DESC LIMIT 10) as biete_tabelle

    UNION

    SELECT * FROM 
    (SELECT
      * 
    FROM 
      angebote
    WHERE 
      (city = '".$_POST['search']."' OR plz = '".$_POST['search']."') AND 
      (art = 'suche')
    ORDER BY id DESC LIMIT 10) as suche_tabelle"
);

Это даст вам результаты, которые вы ищете. Взгляните на здесь пример.

Примечание. Хотя я придерживался немецкого языка для согласованности, я хотел бы посоветовать вам, что лучше всего использовать имена столбцов, переменных и т. д. на английском языке, чтобы разработчикам, которые не говорят, было проще немецкий, чтобы прочитать ваш код.

07.04.2016
  • Эй, спасибо за вашу помощь, проблема в том, что это даст мне 18 результатов, независимо от того, сколько из них относятся к типу (art =suche) или (art=biete). Это займет последние 18 (поскольку id автоматически увеличивается и упорядочивается им DESC). Но мне нужно ровно 18 типа (art =suche) и 18 типа (art=biete), так как искусство в любом случае либо biete, либо такое , вы можете удалить весь оператор AND, но он все равно выдаст 18 результатов, но без учета количества каждого типа, надеюсь, это понятно: / Я думаю, что в конце концов мне придется сделать это совершенно по-другому: P 07.04.2016
  • @Svrex - Пожалуйста, посмотрите еще раз. Я обновил ответ и скрипку до решения, которое вы ищете. Сначала я неправильно понял ваш вопрос, извините за это 08.04.2016
  • Я думаю, что проблема, с которой вы столкнулись, заключалась в отсутствующем псевдониме, который привел к ошибке sql. Попробуйте удалить их в скрипке 08.04.2016
  • Ты человек! :D Работает отлично! вы не поверите, как я этому рад. Большое спасибо 08.04.2016
  • Спасибо за розы ;) рада, что смогла помочь! 08.04.2016
  • Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

    Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
    В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]