Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 12.12.2012
Сообщений: 31

Выбор записи по нескольким направлениям

23.01.2014, 23:31. Показов 918. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Прошу помощи по следующему вопросу: к примеру имеется сайт, посвященный музыке, так вот, мне нужно сделать так, чтобы к примеру одна песня выбиралась по нескольким параметрам, ну например, она относится и к рок направлению, и к рэп направлению. Нужно сделать так, чтобы при запросе рок или рэп вылезала одна и та же песня, т.е. относится к двум записям сразу. Не знаю как это еще объяснить, надеюсь вы поймете что я имел ввиду. Заранее спасибо.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.01.2014, 23:31
Ответы с готовыми решениями:

Массив структур: добавление записи, удаление записи, поиск по одному или нескольким из полей
Необходимо реализовать базу данных с полями «Фамилия», «Имя», «Отчество», «Пол», «Год рождения». Каждая запись должна представлять собой...

ListView: добавление записи, выбор записи, удаление записи
на форме есть три текст бокса: textbox1(имя), textbox2(фамилия), textbox3(отчество), textbox4(выбранное) кнопка Button1(добавить),...

Выбор по нескольким атрибутам
Подскажите как сделать выбор по нескольким атрибутам, к примеру мне надо выбрать tr у которой есть td c атрибутом alt=1 и (AND) td c...

8
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
24.01.2014, 09:31
Должна быть таблица песен, таблица жанров песен (рок, рэп) и таблица связи, где есть колонки с id песни и id жанра. А дальше элементарные SQL-запросы
0
0 / 0 / 0
Регистрация: 12.12.2012
Сообщений: 31
24.01.2014, 10:23  [ТС]
Можешь привести хоть какой-нибудь простенький пример? Что-то я не понял про таблицу связи. Заранее спасибо.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
24.01.2014, 10:55
Лучший ответ Сообщение было отмечено Taatshi как решение

Решение

song
-----
song_id
song_name
.....

genre
-----
genre_id
genre_name
...

link
----
song_id
genre_id

Соответственно, если песня с song_id = 10 относится к 3 жанрам, то по ней будет 3 строки, скажем
SQL
1
2
3
4
5
song_id  | genre_id
----------------
10             1
10             3
10             8
1
0 / 0 / 0
Регистрация: 12.12.2012
Сообщений: 31
24.01.2014, 11:25  [ТС]
Спасибо тебе огромное! Я то балбес ломал голову как их соединить! Грешны делом думал как-то через тип данных SET как-то это все делается! Премного благодарен тебе!
0
0 / 0 / 0
Регистрация: 12.12.2012
Сообщений: 31
27.02.2014, 18:17  [ТС]
Привет. Можешь еще раз мне помочь? Вставить данные в одну таблицу - это не проблема, а вот как одновременно вставить изменяющееся количество данных? Вот к примеру в связующую таблицу link. Заранее спасибо.
0
6 / 6 / 3
Регистрация: 05.02.2014
Сообщений: 91
28.02.2014, 03:41
SQL
1
2
3
4
INSERT INTO link(song_id,genre_id)
SELECT 10,g.song_id
FROM genre g
WHERE song_id IN (1,3,8) // сюда подставляешь нужные значения через заптую
Как то так
0
0 / 0 / 0
Регистрация: 12.12.2012
Сообщений: 31
28.02.2014, 09:28  [ТС]
Спасибо за ответ, но ты немножко не понял. В строке:
SQL
1
INSERT INTO link (song_id, genre_id) VALUES (10, 1)
количество значений
SQL
1
VALUES (10,1),(10, 3)
меняется. Как это реализовать? Я так полагаю это реализуется средствами PHP?
0
6 / 6 / 3
Регистрация: 05.02.2014
Сообщений: 91
01.03.2014, 17:49
WHERE song_id IN (1,3,8) ну вот сюда в скобки вместо цифр можно например запрос вставить, только надо что бы он только одно поле возвращал, с таким же типом данных, с нужными тебе значениями - это как вариант, например так:
SQL
1
2
3
4
INSERT INTO link(song_id,genre_id)
SELECT 10,g.song_id
FROM genre g
WHERE song_id IN (SELECT col1 FROM table1 WHERE <какоето условие>)

Ну или можно конечно в PHP, при формировании запроса, нужные значения подставлять в скобки, ну или как ты написал VALUES (10,1),(10, 3)
Вариантов на самом деле много
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.03.2014, 17:49
Помогаю со студенческими работами здесь

Выбор по нескольким условиям
Есть простой запрос mysqli_query($log_db, &quot;SELECT * FROM users_db WHERE user_name='$e_mail' OR e_mail='$e_mail'&quot;); Всё очень...

Выбор элементов по нескольким classname
Суть в том, что есть куча элементов с классом class1, некоторые из них имеют еще и class2. Нужно выбрать все элементы, которые принадлежат...

Выбор по нескольким полям таблицы
Всем привет! Вот такая вот задача у меня... Есть таблица (cents) вот такого вида: http://picone.ru/thumbs/20-aztdizrt.jpg И...

Выбор элементов по нескольким значениям
Всем привет, так сложилось что теперь редко работаю с mysql - затупил в простом запросе Есть товар, у него свойства Хранятся...

Присвоение записи нескольким строкам
Здравствуйте! Подскажите, пожалуйста, как сделать так, чтобы все строки колонки number получили значение из dbedt1. В моем коде идет...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru