Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/13: Рейтинг темы: голосов - 13, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 13.05.2018
Сообщений: 35
SQLite

Вывод данных из базы в label и radiobutton

03.10.2019, 12:00. Показов 2675. Ответов 7

Студворк — интернет-сервис помощи студентам
Есть такая проблема:
В базе данных на SQLite есть две таблицы:
- Вопросы (idВопроса, вопрос);
- Ответы (idОтвета, idВопроса, Ответ).
На главной форме есть кнопка "Начать тест", при нажатии которой открывается следующая форма на которой есть 1 label, 3 radiobutton и кнопка далее.
Вопрос заключается в следующем, как при загрузке формы с тестом вывести вопрос и ответы к нему, и при нажатии кнопки далее выводить следующие вопросы с ответами.
P.S. Количество ответов к каждому вопросу фиксировано и равно 3.
Заранее спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.10.2019, 12:00
Ответы с готовыми решениями:

Вывод из базы данных в label
Здравствуйте, я недавно начал изучать С#. Так вот у меня база данных Database1.mdf в ней таблица Table1 мне необходимо отобразить...

Вывод данных из базы sql в label
Доброго времени суток! Помогите пожалуйста реализовать вывод данных из БД MS SQL Server 2008. На форме есть DBLookupCombobox и 7...

Вывод названий таблиц базы данных в Link Label
Добрый день. Нужна ваша помощь. Пытаюсь вывести данные из БД в компонент linklabel, однако отображается лишь один элемент, несмотря на то,...

7
 Аватар для Kazbek17
1484 / 939 / 454
Регистрация: 06.02.2012
Сообщений: 2,868
03.10.2019, 14:33
xdjokerx, Вы бы хоть код что-ли выложили.

Пробуйте так, что я могу сказать. Какой вопрос, такой ответ. Телепаты выходные.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
    SQLiteConnection connect = SQLiteConnection("Строка подключения");
    public static DataTable RunQuery (string script)
    {
            connect.Open();
            SQLiteDataAdapter dataAdapter = new SQLiteDataAdapter(script, connect);
            DataTable Table = new DataTable();
            dataAdapter.Fill(Table);
            connect.Close();
        return Table;
    }
 
        private void btnTest_Click (object sender, EventArgs e)
        {
            object [] Data  = RunQuery("SELECT вопрос, Ответ FROM Ответы 
                                             Join Вопросы ON Вопросы.idВопроса = Ответы.idОтвета").Rows [0].ItemArray;
   
            object question = data[0];//Вопрос
            object answer = data[1];//Ответ
 
          //Теперь вам нужно передать эти данные в форму2
         //Есть вариант такой: Создать класс с статическими полями и передавать данные в него, после активации
        //формы 2 считывать данные с класса.
        //Я думаю что выше код вы уже сами прикрутите к кнопке "Следующий вопрос", поскольку я не видел вашего 
        алгоритма 
        }
0
 Аватар для Кузнец кода
169 / 188 / 35
Регистрация: 21.01.2018
Сообщений: 230
03.10.2019, 14:38
А как вы получаете данные из БД? Приведите код, где вы запнулись!
0
0 / 0 / 0
Регистрация: 13.05.2018
Сообщений: 35
03.10.2019, 15:03  [ТС]
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
public int x = 1;
 
        private void mbStart_Click(object sender, EventArgs e)
        {
            string connectionString = "Data Source = Test_Kettela.db";
 
            string sqlExpression = "SELECT Вопрос FROM Вопросы WHERE idВопроса=" + x + "";
 
            string sqlExpression2 = "SELECT Ответ FROM Вопросы JOIN Ответы WHERE  " + x + " = Ответы.idВопроса";
 
            using (SQLiteConnection connection = new SQLiteConnection(connectionString))
            {
                connection.Open();
 
                SQLiteCommand command = new SQLiteCommand(sqlExpression, connection);
                SQLiteCommand command2 = new SQLiteCommand(sqlExpression2, connection);
 
                string name = command.ExecuteScalar().ToString();
 
                string name2 = command2.ExecuteScalar().ToString();
 
                l1.Text = name;
 
                mt1.Text = name2;
            }
 
            x++;
        }
Это код кнопки при нажатии на которую в label (l1) заносятся вопросы из базы данных
И таким же образом выводятся ответы, но пока что только 1. Как вывести 3 я не понимаю
0
0 / 0 / 0
Регистрация: 13.05.2018
Сообщений: 35
03.10.2019, 15:19  [ТС]
Вот как это должно выглядеть
Миниатюры
Вывод данных из базы в label и radiobutton   Вывод данных из базы в label и radiobutton  
0
 Аватар для Kazbek17
1484 / 939 / 454
Регистрация: 06.02.2012
Сообщений: 2,868
03.10.2019, 16:37
xdjokerx,
В такой задачи нужно алгоритм вести так: Должны быть группы вопросов.
Каждый раз при выборе группы теста, программа должна считать (idВопроса начальное/конечное) теста. т.е при загрузки теста "Животные", начальное idВопроса начинается с 10 номера а конечное 20.
Значит нужно создать две переменные (Int-step/end) и сделать выборку для них по idВопроса , затем при каждом клике ++step.

Так же нужно в кнопке прописать условие на
C#
1
2
3
4
5
6
7
8
9
10
11
if(end > step )
{
  buttonNext.Enabled = false;
} 
else
{
     string sqlExpression2 = "SELECT Ответ FROM Вопросы JOIN Ответы WHERE  " + x + " = ++step";
     //.....
    //....
   //..... и.т.д
}
0
0 / 0 / 0
Регистрация: 13.05.2018
Сообщений: 35
03.10.2019, 19:24  [ТС]
Но в приложении нет групп тестов, там есть 1 тест в котором 180 вопросов и 3 * 180 вариантов ответа
И опять же, ответы выводятся только в 1 radiobutton (mt1), как вывести оставшиеся два ответа в mt2 и mt3
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
04.10.2019, 09:46
Цитата Сообщение от xdjokerx Посмотреть сообщение
- Ответы (idОтвета, idВопроса, Ответ).
И как вы будете определять, какой из них правильный?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.10.2019, 09:46
Помогаю со студенческими работами здесь

Вывод ответа результата запроса с базы данных в label
Составил запрос который рассчитывает количество записей определенного IDN за последние 3 дня: "SELECT DISTINCT COUNT(ID) AS FIELD_1...

Вывод текста из БД в Label и RadioButton
Добрый вечер!!! Гляньте на убогую реализацию подобия вывода тестов и ткните меня носом, что я делаю не так? Вот вылетающая...

Передача данных из Radiobutton в Label
Слезно прошу помочь и в этом: покажите пожалуйста как вообще по "номерам строк" в метку передавать данные? -В первой...

Использование RadioButton из имеющейся базы данных
B LibreOffice Base была создана простейшая анкета. Поставлена задача перенести БД в SQL и сделать в виде обычного исполняемого файла....

Вывод времени из базы в Label
Доброе время суток. (я наверное все тут уже надоел :-( ) Есть в базе время 14:29:55 при выводе из DGV (двойным кликов) в label выводится...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через 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-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru