|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
|||||||||||
MS Access Составить запрос, работающий с полями, допускающими несколько значений20.04.2020, 20:40. Показов 954. Ответов 17
Метки нет (Все метки)
Имеется база данных, в которой несколько полей допускают несколько значений, которые берутся из таблиц-списков с помощью запросов.
В программе при запросе:
Как это исправить?
0
|
|||||||||||
| 20.04.2020, 20:40 | |
|
Ответы с готовыми решениями:
17
Несколько значений за один запрос Передать в запрос сразу несколько значений |
|
14298 / 9383 / 1353
Регистрация: 21.01.2016
Сообщений: 35,374
|
||
| 21.04.2020, 04:01 | ||
|
В вашем случае, по мимо таблиц Game и Genre, нужна ещё таблица GameGenre для моделирования связи многие-ко-многим. Тогда строка "Жанр Игры" из таблицы Game развернётся в набор строк в таблице GameGenre. Не стесняйтесь погуглить про этот тип связи.Ну и связанные данные из разных таблиц вытаскиваются оператором JOIN. Тоже можно погуглить как им пользоваться.
1
|
||
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
|
| 21.04.2020, 05:26 [ТС] | |
|
Однако сам MS Access позволяет делать такое стандартными средствами, а именно с помощью меню "Мастер подстановки..." в выборе типа данных.
Собственно это та самая причина, почему я решил попробовать так сделать, чтобы не плодить большого числа таблиц.
0
|
|
|
14298 / 9383 / 1353
Регистрация: 21.01.2016
Сообщений: 35,374
|
||
| 21.04.2020, 05:36 | ||
|
DontRobot, писать числа через запятую вы можете в любое текстовое поле в любой СУБД)
0
|
||
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
||||||
| 21.04.2020, 14:41 [ТС] | ||||||
|
Обратите внимание на 3 скрин, там отображаются непосредственно значения из таблиц, а не их ID.
К тому же, в базе данных побольше, таких таблиц-справочников может быть огромное количество, это что же, нужно будет для каждой из них создавать отдельную таблицу для связи? Добавлено через 1 час 14 минут Пока что пришла мысль сделать так:
А так как таких полей там целых 4, то общее количество запросов будет аж <количество записей>*4+1 Добавлено через 8 минут Забыл написать WHERE id = <ID записи>
0
|
||||||
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
|
| 21.04.2020, 14:51 [ТС] | |
|
Почтальон, cпасибо за невероятно содержательный ответ.
Но с некоторой версии Access появилась возможность создавать поля с несколькими значениями без связи через дополнительную таблицу, тем самым сделав более удобное редактирование для пользователей БД.
0
|
|
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
|
| 21.04.2020, 15:15 [ТС] | |
|
Почтальон, допустим я сделал все "по правильному" через промежуточные таблицы, чтобы получилась связь многие-ко-многим
Теперь вопрос в том, насколько удобно это редактировать (изменять ID'шники не так уж и классно, когда справочников больше 30) Да и запрос к этому делу будет сложно построить, а ответ будет просто "прекрасен". А если делать отдельные запросы под каждое такое "поле", то чем это лучше моего варианта?
0
|
|
|
управление сложностью
|
|
| 21.04.2020, 15:25 | |
|
По Game.Id из таблицы GameGenre дергаете зависимые данные, у вас получается список жанров, принадлежащих игре. Далее этот список куда-то выводите (можете даже собственный контрол придумать) и работаете с ним - удаляете, добавляете, редактируете записи и т.п. И заметьте, количество жанров теперь не ограничено
0
|
|
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
||||||
| 21.04.2020, 15:31 [ТС] | ||||||
|
Почтальон, в том и проблема, что было абсолютно тоже самое, но без промежуточной таблицы. Количество жанров никак не было ограничено. В полях, которые могут содержать несколько значений, по факту хранятся те же самые ID записей из справочников (как в GameGenre, например, но в Access отображаются не ID, а значения) и обратиться к ним можно точно также с помощью отдельного запроса, как я уже писал выше:
Таким образом это удобнее редактировать (просто ставить галочки в выпадающем меню, в котором написаны не ID, а непосредственно сами значения), да и запрос будет не намного сложнее, а с точки зрения производительности такой же.
0
|
||||||
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
||||||
| 21.04.2020, 15:57 [ТС] | ||||||
|
Почтальон, например так:
Вероятно, можно сделать проще, но это первое, что пришло в голову
0
|
||||||
|
управление сложностью
|
|
| 21.04.2020, 16:03 | |
|
Сами как думаете, насколько он оптимален, если в случае с промежуточной таблицей вопрос решается одним селектом ?
А теперь удалите какой-нибудь жанр и посмотрите, что для этого нужно.
0
|
|
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
|
| 21.04.2020, 16:13 [ТС] | |
|
Здесь подзапрос нужен был лишь для того, чтобы получить id жанра.
В то время, как в программе можно будет реализовать это так, чтобы не приходилось делать подзапросы, например, чтобы это был список жанров, которым присваивается ID при инициализации программы (понадобится ровно 1 запрос). Действительно, удалять не очень удобно, ибо приходится убирать вручную значения из записей, но удаление тут и не предполагалось, на крайняк можно написать макрос или реализовать удаление, непосредственно из программы. Однако в обмен на это неудобство мы получаем удобство при заполнении таблиц.
0
|
|
|
0 / 0 / 0
Регистрация: 18.09.2016
Сообщений: 34
|
|
| 21.04.2020, 16:54 [ТС] | |
|
Почтальон, можно закрыть вопрос и пометить ответом 5 сообщение в теме?
0
|
|
|
14298 / 9383 / 1353
Регистрация: 21.01.2016
Сообщений: 35,374
|
||||
| 22.04.2020, 10:18 | ||||
|
0
|
||||
| 22.04.2020, 10:18 | |
|
Помогаю со студенческими работами здесь
18
Запрос с условием отбора данных по списку, имеющему несколько значений ACCESS Как будет выглядеть запрос который добавляется в один столбик несколько значений? Запрос работающий с несколькими таблицами Запрос работающий с задаваемыми таблицами Сложный запрос, работающий с бинарным деревом Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|