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

Как вывести данные из БД в textbox

21.12.2021, 21:31. Показов 1982. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Подскажите, пожалуйста. Делаю ежедневник, есть главная форма на которой расположен DataGridView, в который вывожу данные из БД. Есть еще одна форма, при помощи которой заношу данные в БД, на этой форме 2 textbox'а. Необходимо реализовать обновление данных, само обновление работает (запись в БД меняет в гриде тоже меняет) как это происходит - нажимаю на строку в гриде, затем кнопку изменить запись, открывается вот эта вторая форма вношу новые данные.
В чем сложность - необходимо сделать так, чтобы по нажатию на кнопку "изменить" открывалась вторая форма с заполненными textbox информацией из БД выбранной для изменения строки.
Отдельный класс по работе с БД:
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace Virtual_Assistant
{
    static class DBWorker
    {
        public static string connectionStrings; //в этом поле хранится строка подключения к БД
 
        static SqlConnection sqlConnection; //ссылка на объект SqlConnection
 
        static SqlDataAdapter adapter;
 
        static DataSet dataset;
 
 
        public static void OpenConnection() //метод, устанавливающий соединение с БД
        {
            connectionStrings = "Data Source=(LocalDB)\\MSSQLLocalDB;AttachDbFilename=C:\\Diplom\\Virtual Assistant\\Virtual Assistant\\DB.mdf;Integrated Security=True";
            sqlConnection = new SqlConnection(connectionStrings);
            sqlConnection.Open();
        }
 
        public static void ExecuteQuery(string query) // метод для команд INSERT, UPDATE, DELETE
        {
            SqlCommand command = new SqlCommand(query, sqlConnection);
            command.ExecuteNonQuery();
        }
 
        public static void CloseConnection() //метод, закрывающий соединение с БД
        {
            sqlConnection.Close();
        }
 
        public static void Execute(string query) // метод для команды SELECT
        {
            adapter = new SqlDataAdapter(query, sqlConnection);
            dataset = new DataSet();
            adapter.Fill(dataset);
        }
 
        public static string Sel(string query) // метод для вывода 1 строки
        {
            SqlCommand command = new SqlCommand(query, sqlConnection);
            SqlDataReader reader = command.ExecuteReader();
            string response = null;
            while(reader.Read())
            {
                response = reader[0].ToString();
            }
            reader.Close();
            return response;
        }
 
        public static void ShowNote(Main m)
        {
            Execute(@"SELECT * FROM Note");
            m.D_Note.DataSource = dataset.Tables[0];
            m.D_Note.Columns[3].Visible = false;
        }
 
        public static void ShowTask(Main m)
        {
            Execute(@"SELECT * FROM Task");
            m.D_Task.DataSource = dataset.Tables[0];
            m.D_Task.Columns[0].Visible = false;
        }
    }
}
Код нажатия на клавишу "изменить":
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public void изменитьЗаметкуToolStripMenuItem_Click(object sender, EventArgs e)
        {
            ShowDialogNote();
            Note note = new Note(this);
            if (D_Note.SelectedCells.Count > 0)
            {
                int id = Convert.ToInt32(D_Note.CurrentRow.Cells[3].Value);
                string result =  DBWorker.Sel(@"SELECT Текст FROM Note WHERE Id=" + id);
                note.Txt2 = result.ToString();
                string result2 = DBWorker.Sel(@"SELECT Заголовок FROM Note WHERE Id=" + id);
                note.Txt = result2.ToString();
                
            }
        }
Часть кода из второй формы доступ к textbox:
C#
1
2
3
4
5
6
7
8
9
10
11
        public string Txt
        {
            get { return heading_note.Text; }
            set { heading_note.Text = value; }
        }
 
        public string Txt2
        {
            get { return Text_Note.Text; }
            set { Text_Note.Text = value; }
        }
В переменных result и result2 нужные данные заносятся, но форма открывается с пустыми textbox. Как занести данные из БД в textbox'ы, чтобы они не открывались пустыми?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.12.2021, 21:31
Ответы с готовыми решениями:

Как вывести данные из dataGridView в textBox?
Здравствуйте. Я новичок в этом. У меня есть 2 формы.в одном есть данные в datagridview из базы Access. У меня при нажатие на какой нибудь...

Как вывести данные из таблицы в Textbox
Мне нужно чтобы программа произвела вывод данных из таблицы в TextBox, Sql есть я не знаю как вызвать функцию которая отобразит нужные мне...

Как вывести данные в textbox из другого потока?
Добрый день, как вывести данные, допустим, в textbox из другого потока? TextBox t =...

6
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
23.12.2021, 10:02
Лучший ответ Сообщение было отмечено IIIIIIIIIgor как решение

Решение

IIIIIIIIIgor, пример создания формы для редактирования записи грида.
Вложения
Тип файла: zip DataRowEditor.zip (48.5 Кб, 6 просмотров)
1
3 / 3 / 0
Регистрация: 23.12.2016
Сообщений: 263
25.12.2021, 12:42  [ТС]
Спасибо за пример. Но в нем же не реализовано то что мне нужно. Мне нужно чтобы когда вторая форма открылась, texbox'ы на ней были заполнены информацией из той строки, которую я хочу отредактировать. Сможете подсказать как это реализовать?
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
25.12.2021, 14:23
Лучший ответ Сообщение было отмечено IIIIIIIIIgor как решение

Решение

IIIIIIIIIgor, в конструкторе формы редактирования сделать так:
C#
1
2
textBoxName.Text = Convert.ToString(row["Name"]);
numericUpDownCount.Value = Convert.ToInt32(row["Pieces"]);
1
3 / 3 / 0
Регистрация: 23.12.2016
Сообщений: 263
25.12.2021, 15:23  [ТС]
Спасибо все получилось прикрутить в свой проект!!
0
3 / 3 / 0
Регистрация: 23.12.2016
Сообщений: 263
03.01.2022, 11:01  [ТС]
Здравствуйте!
Только сейчас заметил, что теперь перестала работать кнопка "Добавить" (то что обсуждалось в этой теме работает), когда нажимаю на эту кнопку должна отобразиться вторая форма с пустыми textbox для ввода данных.
Если сделать как у вас в примере:
C#
1
2
3
4
5
6
7
8
DataTable dt = new DataTable();
 
 public void ShowDialogNote() //выводит на экран форму Note
        {
            DataRow row = dt.NewRow();
            Note note = new Note(this, row);
            note.ShowDialog();
        }
То при нажатии получаю такую ошибку: System.ArgumentException: "Столбец "Заголовок" не принадлежит таблице ."

А если делаю так:
C#
1
2
3
4
5
 public void ShowDialogNote() //выводит на экран форму Note
        {
            Note note = new Note(this, null);
            note.ShowDialog();
        }
То получаю следующее: System.NullReferenceException: "Ссылка на объект не указывает на экземпляр объекта."

row было null.

Все эти ошибки возникают в строке:
C#
1
heading_note.Text = Convert.ToString(row["Заголовок"]);
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
06.01.2022, 17:39
IIIIIIIIIgor, вы создали пустой DataTable
Цитата Сообщение от IIIIIIIIIgor Посмотреть сообщение
DataTable dt = new DataTable();
Откуда в нем возьмутся столбцы?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.01.2022, 17:39
Помогаю со студенческими работами здесь

как вывести данные из базы mysql в textbox?
есть датагрид, в нём краткая информация по некоторым фирмам, при щелчке на одну из них открывается другая форма, на которой будет...

Как вывести данные из нужной ячейки access в TextBox?
Здравствуйте! Как обновить из TextBox в access разобрался! Sub UpdateStr(ByVal KeyValue As Integer) SqlCom = New...

Как сделать поиск определенного слова по базе и вывести все данные в TextBox?
Как сделать поиск определенного слова (допустим возьмем из текстбокса) по базе и вывести все данные в текстбокс. Т.е. если ищем слово...

Вывести данные из List (в листе структура Struct (в структуре данные формата int, short, byte) в textBox
Не выводятся данные

есть заполненная таблица в базе данных и textBox, как изменить данные таблицы данными из textBox??
есть заполненная таблица в базе данных и textBox, как изменить данные таблицы данными из textBox? начал так: private void...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
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 На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru