Вопрос по выборке данных из БД

MySQL базы данных sql бд

В поле marks может хранится просто число, например 3 или 5, а могут быть перечислены числа - например 2,4,5,8
Из формы приходит число, например 5 и нужно сравнить это число с числом(или числами) в поле marks и занести в выборку все строки если числа совпали или число из формы присутствует в числах в поле marks.

Если в поле marks оказалось одно число, то понятно можно просто написать


Код:
.... WHERE marks='".$num_from_form."' AND ...



А если в поле marks оказался набор чисел? Как построить запрос в этом случае?
И главное что в этом случае запрос был универсальным, т.к. , повторюсь, поле marks может содержать как просто одно число, так и числа перечисленные через запятую. т.е. примерно так
3
5,8,9
2
1,4,8,9
4

Примечание:
Подскажите пожалуйста как сделать правильно
Ответы:
Может, если еще не поздно, лучше подумать о нормализации базы?
Сделать правильно и не мучиться, это как бы лучше, чем сделать неправильно, и потом мужественно преодолевать возникшие проблемы, наподобие описанной.
Правильно будет вынести marks в отдельную таблицу, и хранить каждую оценку отдельно.
Ну и универсальный запрос (получить все строки, если среди marks есть 5) тогда будет примерно таким:
"SELECT DISTINCT table.* FROM table JOIN marks ON marks.tableId = table.id WHERE marks.tableId IN (SELECT tableId FROM marks WHERE mark = 5)"
Сами marks удобнее будет вытащить отдельным запросом.


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

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

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.