С Новым годом! Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
.NET
133 / 91 / 44
Регистрация: 17.08.2015
Сообщений: 296

Вывод информации из базы данных в dataGrid

03.07.2019, 11:37. Показов 2917. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, имеется код с помощью которого у меня выводится информация из базы данных в таблицу dataGrid

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
string connectionString = @"Data Source=(LocalDB)\MSSQLLocalDB;Initial Catalog=test;Integrated Security=True";
            string sql = "SELECT * FROM [Phonebook]";
            usersTable = new DataTable();
            connection = new SqlConnection();
            try
            {
                connection = new SqlConnection(connectionString);
                SqlCommand command = new SqlCommand(sql, connection);
                adapter = new SqlDataAdapter(command);
                adapter.InsertCommand = new SqlCommand("sp_Phonebooknew");
                adapter.InsertCommand.CommandType = CommandType.StoredProcedure;
                adapter.InsertCommand.Parameters.Add(new SqlParameter("@Name", SqlDbType.NVarChar, 50, "Name"));
                adapter.InsertCommand.Parameters.Add(new SqlParameter("@Dnumber", SqlDbType.NVarChar, 50, "Dnumber"));
                adapter.InsertCommand.Parameters.Add(new SqlParameter("@Tnumber", SqlDbType.NVarChar, 50, "Tnumber"));
                adapter.InsertCommand.Parameters.Add(new SqlParameter("@Otnow", SqlDbType.NVarChar, 50, "Otnow"));
                SqlParameter parameter = adapter.InsertCommand.Parameters.Add("@Id", SqlDbType.Int, 0, "Id");
                parameter.Direction = ParameterDirection.Output;
 
                connection.Open();
                adapter.Fill(usersTable);
                dataGrid.ItemsSource = usersTable.DefaultView;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
            finally
            {
                if (connection != null)
                    connection.Close();
            }
Понадобилось переписать под SQLite, но я слышал что SQLite не поддерживает хранимые процедуры..
Не подскажете как это можно переделать под SQLite?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.07.2019, 11:37
Ответы с готовыми решениями:

Вывод информации в textbox из DataGrid WPF
Как сделать, чтобы при выборе любой строки в DataGrid, вся информация которая записана в БД, выводилась в textbox? // Писал код, но увы, не...

Строки DataGrid и вывод дополнительной информации под каждой строкой по клику
Ситуация: надо вывести доп информацию. Есть DataGrid, в нём куча строк. При нажатии на кнопку в строке - появляеться доп. информация....

Обновление изменений в DataGrid из базы данных
Добрый день. Столкнулся с проблемой разрабатывая простое сервер - клиент приложение. У меня есть основная форма с датагридом, и вторая...

8
управление сложностью
 Аватар для Почтальон
1693 / 1306 / 259
Регистрация: 22.03.2015
Сообщений: 7,545
Записей в блоге: 5
03.07.2019, 11:52
M1ke423, а где вы тут используете хранимые процедуры ?
0
.NET
133 / 91 / 44
Регистрация: 17.08.2015
Сообщений: 296
03.07.2019, 12:05  [ТС]
Цитата Сообщение от Почтальон Посмотреть сообщение
M1ke423, а где вы тут используете хранимые процедуры ?
C#
1
2
adapter.InsertCommand = new SqlCommand("sp_Phonebooknew");
                adapter.InsertCommand.CommandType = CommandType.StoredProcedure;
тут подключается хранимая процедура

Добавлено через 4 минуты
После того как переписал под SQLite, MessageBox с Exception выдаёт = "Указанный метод не поддерживается"

Добавлено через 1 минуту
А в режиме Дебага после строки
C#
1
adapter.InsertCommand.CommandType = CommandType.StoredProcedure;
улетает сразу на

C#
1
2
3
4
catch (Exception ex)
            {
                System.Windows.Forms.MessageBox.Show(ex.Message);
            }
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
03.07.2019, 13:58
Цитата Сообщение от M1ke423 Посмотреть сообщение
но я слышал что SQLite не поддерживает хранимые процедуры
Таки да. Аргументацию можно почитать здесь: http://sqlite.1065341.n5.nabbl... 95348.html
Судя по г-коду, написанному для MS SQL, вам лучше показать код, написанный для SQLite.
0
.NET
133 / 91 / 44
Регистрация: 17.08.2015
Сообщений: 296
03.07.2019, 14:07  [ТС]
Цитата Сообщение от Igr_ok Посмотреть сообщение
лучше показать код, написанный для SQLite.
В том то и дело что кода для SQLite так такового у меня нет..
Он ничем не отличается от кода для MS SQL
Разве что меняется SQLConnection на SQLiteConnection и прочее



P.S я на c# около месяца, совсем еще зелёный
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
03.07.2019, 17:09
M1ke423, https://www.youtube.com/watch?v=8YdjguVZID8
1
.NET
133 / 91 / 44
Регистрация: 17.08.2015
Сообщений: 296
03.07.2019, 18:08  [ТС]
Цитата Сообщение от Igr_ok Посмотреть сообщение
Спасибо, но это не совсем то что мне нужно.. В листбокс выводить я знаю как.

Конкретно нужен датагрид так как есть возможность редактирования ячеек (как в Excel) и обновления информации в бд
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
03.07.2019, 19:10
Лучший ответ Сообщение было отмечено M1ke423 как решение

Решение

M1ke423, делаете выборку данных и отображаете их в гриде. У вас же всё написано:
Цитата Сообщение от M1ke423 Посмотреть сообщение
dataGrid.ItemsSource = usersTable.DefaultView;
Если нужно редактировать данные, используйте CommandBuilder для создания команд INSERT,UPDATE,DELETE в DataAdapter.
https://csharp.hotexamples.com... mples.html
1
.NET
133 / 91 / 44
Регистрация: 17.08.2015
Сообщений: 296
04.07.2019, 07:36  [ТС]
Цитата Сообщение от Igr_ok Посмотреть сообщение
Если нужно редактировать данные, используйте CommandBuilder для создания команд INSERT,UPDATE,DELETE в DataAdapter.
https://csharp.hotexamples.com... mples.html
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
string connectionString = @"Data Source=C:\Users\it\test.db";
            string sql = "SELECT * FROM [Phonebook]";
            usersTable = new DataTable();
            sqlconnection = new SQLiteConnection();
            try
            {
                sqlconnection = new SQLiteConnection(connectionString);
                SQLiteCommand command = new SQLiteCommand(sql, sqlconnection);
                sqladapter = new SQLiteDataAdapter(command);
                SQLiteCommandBuilder cb= new SQLiteCommandBuilder(sqladapter);
                sqladapter.InsertCommand = cb.GetInsertCommand();
                sqladapter.UpdateCommand = cb.GetUpdateCommand();
                sqladapter.DeleteCommand = cb.GetDeleteCommand();              
                sqlconnection.Open();
                sqladapter.Fill(usersTable);
                dataGrid.ItemsSource = usersTable.DefaultView;
            }
            catch(Exception ex)
            {
                System.Windows.Forms.MessageBox.Show(ex.Message);
            }
            finally
            {
                if (sqlconnection != null)
                    sqlconnection.Close();
            }

Спасибо, сделал так. Всё работает как надо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.07.2019, 07:36
Помогаю со студенческими работами здесь

DataGrid. Удаление записи из базы данных
Подскажите, пожалуйста. Нужно отлавливать клавишу delete. И при удалении в DataGrid запись ДОЛЖНА удаляться и из БД.

Вывод данных в datagrid
Доброго времени суток. При запросе к sqlite получаю DataRow . Как отобразить полученный DataRow в datagrid? Как добавить в...

Как отобразить нужные мне заголовки в Datagrid вместо заголовков из базы данных
Ребят, подскажите пожалуйста. У меня есть <DataGrid x:Name="dg" >. На нем я отображаю данные из заполненного dataset. ...

Извлечение информации из базы данных в Silverlight 4
Здаравствуйте уважаемые форумчане! У меня следующая проблема. Я создал проект Silverlight Business Application. В solution к нему...

Вывод данных из MSSQL в DataGrid
Всем доброго времени суток, столкнулся практически с детской проблемой и не могу никак решить. Пытаюсь в приложении WPF c помощью DataGrid...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru