Подзапрос Mysql в предложении where, который возвращает значение, разделенное запятыми

Я не очень хорошо разбираюсь в подзапросах, вот примеры таблиц, которые у меня есть.

table customers
=====================
id  | name | order_ids
1   | John | 1,2


table orders
=====================
id  | name
1   | apple
2   | orange

Я пытаюсь получить имена заказов, используя этот запрос, но получаю только один результат. Я не уверен, возможно ли это.

select o.name 
from orders o 
where o.id IN(
    select c.order_ids 
    from customers c 
    where c.id=1
)
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
0
346
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Ваши основные усилия должны быть направлены на исправление вашего дизайна. Вы не должны хранить несколько целочисленных значений в строковом столбце. Если каждый заказ принадлежит одному клиенту, то идентификатор клиента должен храниться в таблице orders. Если заказ может принадлежать нескольким клиентам одновременно, вам нужна таблица-мост с одной строкой для каждого кортежа клиента/заказа.

Тем не менее: для вашего текущего дизайна вы можете использовать find_in_set():

select o.*
from orders o
inner join customers c on find_in_set(o.id, c.order_ids)
where c.id = 1

«Вы должны хранить» или «Вы не должны хранить»?

PaulProgrammer 13.12.2020 20:00

Я согласен с тем, что дизайн БД "испорчен". Но сейчас я не призываю менять дизайн нашей БД.

user3437905 13.12.2020 20:04

@ user3437905 Вы можете обнаружить, что метод FIND_IN_SET() дает правильный результат, но его нельзя оптимизировать с помощью индексов. По мере увеличения количества строк в вашей таблице (как всегда) она будет становиться все медленнее и медленнее. Вы или кто-либо другой в вашем проекте, может принять решение, должны как можно скорее изменить его в нормализованном виде.

Bill Karwin 13.12.2020 20:31

Другие вопросы по теме