Jump to content
  • Sign Up
tor243

Помогите с запросом

Recommended Posts

Имеется таблица table с полями id, refpost, type и comment. Тип поля comment TEXT.

Необходимо получит строки, где refpost у которой type='A' или type='D', который встречается в поле comment.

Пробовал так:

SELECT id, refpost, type, comment
	FROM table
    WHERE comment
    LIKE 
   		(
        SELECT refpost
          	FROM table
          	WHERE type='A'
          	OR type='D'
        )

Без результатов. Выдает ошибку 1242: Subquery returns more than 1 row

Share this post


Link to post
Share on other sites

в вашем случае лучше разбить без вложенного запроса сделать через цикл и для LIKE использовать %...%

Share this post


Link to post
Share on other sites
SELECT * FROM `table` AS t WHERE t.comment LIKE CONCAT('%',t.refpost,'%') AND t.type IN ('A','D')
или так
SELECT * FROM `table` AS t WHERE INSTR(t.comment,t.refpost) AND t.type IN ('A','D')

 

Share this post


Link to post
Share on other sites

я так понял ТС нужно получить refpost из A или D, а потом найти все строки в comment которых упомянут refpost
что-то вроде:
пришел вопрос в тех поддержку (type=A или D)
все последующее общение по данной теме маркируется в comment установленным refpost

возможно я не так понял и тогда предложенные варианты @wwt более чем

Share this post


Link to post
Share on other sites

Switch74, Вы правильно поняли. Первый вариант wwt выдает синтаксическую ошибку а второй выводит только те строки, где type='A' или 'D'. На прикрепленном примере они встречаются и в 'C' и в 'F'.

Share this post


Link to post
Share on other sites

Такс, если я верно понял что нужно получить то вот так:

SELECT 
t.id as id,
t2.refpost as refpost,
t.type as type,
t.comment as comment
FROM `table` as t 
LEFT JOIN `table` t2 ON t2.type IN ('A','D') 
WHERE INSTR(t.comment, t2.refpost)

В итоге выборки должен быть получен массив где

id это идентификатор записи

refpost это рефпост по которому была найдена запись ( он может повторятся если было найдено несколько постов где в поле comment встречается данный refpost, по этому элементу их можно сгруппировать, а очередность комментариев сделать тупо сортировкой по полю id ибо оно уникально и новая запись всегда имеет больший номер)

type это тип записи

comment - сам комментарий

 

ЗЫ Верную работоспособность нужно тестировать ибо я по-быстрому на тестовой базе проверил, и не факт что выборка всегда ведет себя адекватно. Если опять чото не то написал тапками чур не кидаться =)) Я немного не трезв ?

Share this post


Link to post
Share on other sites

wwt, Супер. По крайне мере я вижу уже что-то похожее на то что мне необходимо.

Я Вам очень благодарен. Вы гений.

Очень долго возился и у меня ничего не получалось. Так как я не хорошо разбираюсь в Mysql, пока. Если Вы могли бы объяснить как работает Ваш запрос буду признателен.

Огромное Вам спасибо. 

Share this post


Link to post
Share on other sites

Чтобы понять что происходит нужно убрать условие выборки в основном запросе и добавить в вывод данные

вот так:

SELECT 
t.*,
t2.refpost as t2refpost
FROM `table` as t 
LEFT JOIN `table` t2 ON t2.type IN ('A','D') 

Грубо говоря через джоин к каждой записи таблицы присоединяется каждый вариант refpost у которого тип равен А или D и потом проверяется через INSTR на соответствие условию.

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Similar Content

    • By belhost
      Всем привет!
      Бесплатная консультация по серверам и вопросам настроек, обращайтесь.
      Помогу чем смогу
      ————————————————————————————————
      Также предоставляю услуги:
      - Помощь c серверными рещениями при открытие IT проектов
      - Большой опыт в готовых IT решений для Вашего бизнеса
      - Подбор конфигурации сервера и размещение серверов
      - Регистрация и установка SSL и TLS а также Let's Encrypt
      - Оптимизация сервера под HighLoad. Nginx, PPH-FPM, HHTP2
      - Администрирование Ubuntu, Debian, Centos, Fedora, RedHat
      - Администрирование и мониторинг Windows Server 03/08/12
      - Установка панелей Plesk, ISP manager 4/5, DA, Vesta, WebMin
      - Установка систем виртуализации KVM, OpenVZ, VMWare, Hyper
      - Настройка сервера под Bitrix, WP, Joomla, Drupal, Yii, OpenCart
      - Установка и настройка мониторинга Munin, Nagios, Zabbix, Cacti
      - Гео распределенная фильтрация DDOS атак до 1000Gb/s
      - Организация системы Бэкапирования FTP, ЯД, DropBox, NAS
      - Мониторинг за состоянием сервера и его служб 24х7
      - Оперативное вмешательство при сбоях в работе служб сервера
      - Экстренное обращение к администратору 24х7 по телефону
      - Удаляем трояны/бэкдоры, спамботы, взломщики паролей
      - Удаляем программы-шпионы, DoS/DDoS агенты, iframe вставки
      - Удаляем рекламные блоки и прочие угрозы вашему сайту
      - Сервер БД MySQL, MsSQL, PostgresSQL, MariaDB, Percona
      - Общение с Тех Поддержкой Вашей хостинговой площадкой
      - Установка и настройка proxy сервера на базе Squid, 3proxy, l2tp
      - Установка и настройка почтового сервера Postfix, Exim, SendMail
      - Настройка цифровых подписей почты DKIM, SPF, DMARC, PTR
      - Настройка и установка VPN сервера PPTP, IPSec, L2Tp, OpenVPN
      - Настройка и установка сервера на AWS Amazon EC2, DigitalOcean
      - Администрирование и создание контейнеров Docker
      - Настройка и установка централизованного администрирование Ansible, RunDeck
      ————————————————————————————————
      Мои профили и отзывы на Биржах:
      FL.ru
      Weblancer
      freelancehunt
      freelance.ru
      5bucks.ru
      linkedin.com
      ————————————————————————————————
      Мои контакты:
      Сайт BEL-HOST | SKYPE: sys_admin3 | WhatsApp: +375256122681 | VIBER: +375256122681 | TELEGRAM: @gev511 |
    • By mightybat
      Добрый день.
      Есть форма(опросник), переменных на 200, подскажите как можно ее заполнить на компьютере1, и открыть на компьютере2 уже заполненную?
      Может быть есть человеческий способ, решения данной проблемы? 
      Вижу только вариант 1)сохранить все переменные в mysql 2)на втором компе вытащить из БД 3)воссоздать страницу HTML через echo( куча чекбоксов с oncliсk показывающими дивы, которые замучаюсь переписывать с block на none и наоборот).
    • By flagmanfbe
      Здравствуйте.
      Я веб-разработчик, занимаюсь написанием современных динамических сайтов, сайт, блог и интернет магазин. В реализации использую три движка Joomla, WordPress и Opencart. В зависимости от задачи, выбирается один из этих движков.
      Языки программирования:
          HTML, CSS, Javascript, PHP
      Фреймворки:
          LESS, SASS, Bootstrap, jQuery
      Движки (CMS):
          Joomla, WordPress, Opencart
      Минимальный вариант, готовый сайт за 20$
      • настройка понравившегося шаблона для CMS
      • установка дополнений и их настройка (плагины, модули, компоненты)
      • привязка хостинга к домену
      • установка сайта на хостинг
      • настройка хостинга
      Другие работы:
      • написание шаблона
      • правка шаблона
      • натягивание шаблона на движок
      • установка и настройка дополнительных компонентов для движка
      • установка ваших скриптов на сервер
      • и другие работы...
      Обращайтесь.
      Site: http://rocketusd.ru/napisanie-sajta
      Email: flagmanfbe@gmail.com
      Skype: live:flagmanfbe_1
      Всем удачи в достижении своих целей!!!
  • Member Statistics

    46,897
    Total Members
    1,451
    Most Online
    Neovo
    Newest Member
    Neovo
    Joined
  • Recently Browsing   0 members

    No registered users viewing this page.

  • Спрашивают сейчас

  • Пишут сейчас

    • Дорогие Друзья! Рад вам сообщить о выходе новой версии движка Flextype 0.9.9! В Flextype 0.9.9 достаточно много важных изменений определяющих — то как будет выглядеть финальная версия Flextype 1.0.0, к которой я иду уже более двух лет! Были пересмотрены, обновлены и переписаны ключевые моменты ядра, ответственные за работу с Записями, Коллекциями, Кешем и Rest API. Подробнее в статье: https://vk.com/@flextype-flextype-099-reliz Большое спасибо всем за то, что вы являетесь частью сообщества Flextype!
    • Привет! Меня зовут Евгения и я ищу талантливых программистов в компанию DevCube. https://mydevcube.com/ Это международная компания, которая занимается DevOps, web и software разработками. На данный момент в команду требуются Full stack .NET (Junior & Senior) — 3+ year of commercial experience; — Strong knowledge of Angular 5+; — Strong knowledge of Typescript; — Experience with HTML/HTML5, CSS/CSS3, SCSS; — Good understanding of Git; — Conversational English. Будет плюсом: VB experience Условия: Удаленная работа full-time Зарплата от 10-20$/час по результатам собеседования. Обязательное условие - быть на связи до 21-22:00 по Москве. Для отклика прошу писать на почту: evgeniia.ko@mydevcube.com
    • Привет! Меня зовут Евгения и я ищу талантливых программистов в компанию DevCube. https://mydevcube.com/ Это международная компания, которая занимается DevOps, web и software development. На данный момент в команду требуются PHP developers (Junior & Senior) Requirements: — 3+ year of commercial experience; — Strong knowledge PHP 7+ — Framework knowledge — Conversational English — CSS, Json, HTML5 Будет плюсом: Shopify implementation expertise. Условия: Удаленная работа full-time Зарплата от 10-20$/час по результатам собеседования. Обязательное условие - быть на связи до 21-22:00 по Москве. Для отклика прошу писать на почту: evgeniia.ko@mydevcube.com
  • Popular Contributors

    Nobody has received reputation this week.

×
×
  • Create New...