Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 07.11.2017
Сообщений: 53
MS Access

Создание теста

21.11.2017, 01:49. Показов 3085. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пишу программу с тестированием. Идея такая, хранить вопросы и варианты ответов (три) в базе данных (Access). Предположим что вопросов в базе будет 100. Как мне на форму вывести только 20-30 вопросов в разброс (не по порядку), при этом чтобы ответы тоже менялись местами (не были постоянно в одной и той же точке на форме)? Как лучше сделать базу данных, хранить данные (номер вопроса, вопрос, варианты ответов) в одной таблице или же создать две таблицы, отдельно для вопросов, и отдельно для вариантов ответа?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.11.2017, 01:49
Ответы с готовыми решениями:

Создание программы-теста(оценивание знаний) и вывод теста в форму, с подсчетом оценки(балл за правильный ответ)
Здравствуйте, уважаемые форумчане. У меня назрел еще один вопрос: -Есть задание написать приложение, которое осуществляет...

Создание теста
Доброго времени суток! Мне нужно создать тест, в котором будет 70 вопросов, в каждом вопросе может быть различное количество ответов....

создание теста
1 форма: вопрос и несколько вариантов ответа, ставится галочка правильном варианте (единстванный или несколько правильных из 4 вариантов),...

11
 Аватар для Dinkin
783 / 556 / 136
Регистрация: 31.05.2013
Сообщений: 3,154
Записей в блоге: 3
21.11.2017, 10:38
Доброго!
В Вашем случае, хватит одной таблицы такого формата:
1) id - порядковой номер вопроса, автоинкримент
2) question - сам вопрос, текстовое поле
3) answer - ответ на вопрос текстовое поле

При старте вопроса на клиенте генерируете 20-30 не повторяющих случайных чисел в диапазоне кол-ва вопросов, и по ним (число= id вопросу) делаете выборку.
1
 Аватар для RunningMan
278 / 186 / 75
Регистрация: 12.04.2017
Сообщений: 1,088
Записей в блоге: 2
21.11.2017, 13:00
Цитата Сообщение от Uucyc Посмотреть сообщение
Как лучше сделать базу данных, хранить данные (номер вопроса, вопрос, варианты ответов) в одной таблице или же создать две таблицы, отдельно для вопросов, и отдельно для вариантов ответа?
Ответов на вопрос несколько, значит удобнее сделать две таблицы и связать их отношением
один ко многим по номеру вопроса:
Миниатюры
Создание теста  
1
0 / 0 / 0
Регистрация: 07.11.2017
Сообщений: 53
21.11.2017, 18:57  [ТС]
С таблицами разобрались

Теперь как мне реализовать в Builder'e рандомную загрузку вопросов?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
21.11.2017, 23:05
используй randomize()
1
0 / 0 / 0
Регистрация: 07.11.2017
Сообщений: 53
21.11.2017, 23:08  [ТС]
Если я буду использовать randomize(), вопросы не могут повторится?
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33414 / 21523 / 8237
Регистрация: 22.10.2011
Сообщений: 36,923
Записей в блоге: 12
21.11.2017, 23:22
Лучший ответ Сообщение было отмечено Uucyc как решение

Решение

Могут. Чтобы вопросы не повторялись, нужно заполнить массив числами от 1 до количества вопросов, и перемешать его (для этого в С++ есть свои средства, а есть общие алгоритмы). А потом уже брать по этим индексам вопросы. Тогда они точно не будут повторяться.
1
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
21.11.2017, 23:23
Покажи код что у тебя есть. Запросы какие ты сделал?
1
0 / 0 / 0
Регистрация: 07.11.2017
Сообщений: 53
22.11.2017, 00:59  [ТС]
Пока ещё не делал ничего с тестами, сначала разбираюсь. Есть только база, ну и конечно же есть регистрация и личный профиль, всё. Теперь хочу реализовать тест, вот как, в голове не укладывается, по степенно направляете на светлую мысль...

Добавлено через 12 минут
База у меня построена так:
Первая таблица:
id_quest (код вопроса);
quest (текст вопроса);
Вторая таблица:
id_quest (код вопроса);
id_answers (код ответа);
anwers1 (первый вариант ответа);
anwers2 (второй вариант ответа);
anwers3 (вариант ответа);
Таблицы связаны по id_quest (один ко многим);

Добавлено через 1 час 12 минут
volvo, суть вашей идеи уловил, нужен массив, предположим от 1 до 100. Заполняем через цикл по возрастанию. Потом перетасовываем его и id_quest присваиваем первое число массива. Это всё запихнуть в обработчик OnClick Баттона. Это вы имели ввиду ?
0
 Аватар для RunningMan
278 / 186 / 75
Регистрация: 12.04.2017
Сообщений: 1,088
Записей в блоге: 2
22.11.2017, 07:23
Цитата Сообщение от Uucyc Посмотреть сообщение
База у меня построена так:
Немножко не так.
Одна запись в таблице ответов содержит один вариант ответа.
Вторая таблица вот так:
id_answers (код ответа);
id_quest (код вопроса);
anwers(вариант ответа);

Тогда будет связь по id_quest
Миниатюры
Создание теста   Создание теста   Создание теста  

0
 Аватар для RunningMan
278 / 186 / 75
Регистрация: 12.04.2017
Сообщений: 1,088
Записей в блоге: 2
22.11.2017, 07:24
А если как у Вас, то смысла нет в двух таблицах.
Одну достаточно делать.
0
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
22.11.2017, 08:27
Нее, одну таблицу с вопросами, и подчиненную ей таблицу с ответами, в которой отмечается флагом правильный ответ. Таким образом вы убиваете несколько зайцев. Корректное добавление/удаление вопросов, избавляет от гемора вычислять правильный ответ (даже если их будет несколько в одном вопросе), добавлять произвольное количество вариантов ответа.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.11.2017, 08:27
Помогаю со студенческими работами здесь

создание теста в C++ / помогите !
Получил задание от лектора , создать тест ( 30 вопросов ) , как его сделать , он не обяснил .. исползал весь интернет , но так ничего не...

Перевод из Delphi в C++. Создание теста.
Перевожу программу из Delphi в C++, код элементарноVar Left_N : Integer; // Отступ слева верхней части Top_N : Integer; // Отступ...

Создание теста: реализовать подсчет правильных ответов
Подскажите как сделать что бы программа выводила после завершение работы ответы мои и те которые правильные. Программа такая как на сайте...

Кодирование и декодирование теста
Доброго времени ссуток, есть система тестов в которой сохраняются результаты в txt файл в виду конфидециальности результатов для доступа к...

Простое шифрование теста
Доброго дня или вечера. Требуется помощь в написании программы на bilder 6. Надо вводить текст в Edit. При нажатии на кнопку, он должен...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru