Я не очень хорошо разбираюсь в подзапросах, вот примеры таблиц, которые у меня есть.
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
)
Ваши основные усилия должны быть направлены на исправление вашего дизайна. Вы не должны хранить несколько целочисленных значений в строковом столбце. Если каждый заказ принадлежит одному клиенту, то идентификатор клиента должен храниться в таблице 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
Я согласен с тем, что дизайн БД "испорчен". Но сейчас я не призываю менять дизайн нашей БД.
@ user3437905 Вы можете обнаружить, что метод FIND_IN_SET()
дает правильный результат, но его нельзя оптимизировать с помощью индексов. По мере увеличения количества строк в вашей таблице (как всегда) она будет становиться все медленнее и медленнее. Вы или кто-либо другой в вашем проекте, может принять решение, должны как можно скорее изменить его в нормализованном виде.
«Вы должны хранить» или «Вы не должны хранить»?