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

Insert delete update. все просто

25.05.2015, 19:47. Показов 2115. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
есть приложение которое подключается к базе данных и из БД выгружает в датагрид данные, вот код
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.IO;
using System.Data.Common;
using System.Data.Sql;
 
 
namespace GDP_ITAD_
{
    public partial class Form1 : Form
    {
        //Создаем экземпляр FullDataTable, в который будут помещатся данные
        DataTable FullDataTable = new DataTable();
 
        //Создаем экземпляр FullDataTable для получения структуры таблицы из базы данных
        DataTable ShemaDataTable = new DataTable();
 
        SqlDataReader dataReader;
        SqlCommand myCommand;
        DataTable selectDataTable;
 
        //Создаем объект objectRow для получения информации о числе столбцов
        object[] objectRow;
 
        //Создаем объект myDataRow для помещения записей
        DataRow myDataRow;
 
        public Form1()
        {
            InitializeComponent();
            ConnectToDB();
 
            //FullDataTable.Columns.Clear();
            //FullDataTable.Rows.Clear();
 
            try
            {
 
                myCommand = GlobalVars.conn.CreateCommand();
                myCommand.CommandText = "SELECT * FROM GDP";
                dataReader = myCommand.ExecuteReader();
 
                //Вызываем метод GetShemaTable, который получает схему таблицы из базы
                //и передает ее объекту ShemaDataTable
                ShemaDataTable = dataReader.GetSchemaTable();
 
                //Свойство FieldCount возвращает число столбцов для текущей записи
                //Передаем это значение объекту objectRow
                objectRow = new object[dataReader.FieldCount];
 
                //Определяем структуру объекта FullDataTable
                for (int i = 0; i < dataReader.FieldCount; i++)
                {
                    FullDataTable.Columns.Add(ShemaDataTable.Rows[i]["ColumnName"].ToString(),
                                                ((System.Type)ShemaDataTable.Rows[i]["DataType"]));
                }
 
                //Добавляем записи в объект FullDataTable
                while (dataReader.Read())
                {
                    dataReader.GetValues(objectRow);
                    myDataRow = FullDataTable.Rows.Add(objectRow);
                }
 
                //Определяем источник данныых для элемента datagrid1
                dataGridView1.DataSource = FullDataTable;
 
 
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.ToString());
            }
            finally
            {
                dataReader.Close();
            }
        }
 
        public void ConnectToDB()
        {
            //settings set = new settings();//окно подключения к бд
 
            string connStr;
 
            string address = @".\SQLEXPRESS";
            string user = "SAdmin";
            string password = "2144";
 
            //    string address = @".\SQLEXPRESS";
            //    string user = "SAdmin";
            //    string password = "2144";
 
            connStr = @"Data Source=" + address + "; Initial Catalog=GDP; Persist Security Info=True; User ID=" + user + "; Password=" + password;
            GlobalVars.conn = new SqlConnection(connStr);
            GlobalVars.conn.Open();
        }
 
 
        //объявление глобальных переменных
        public class GlobalVars
        {
            public static SqlConnection conn; //соединение с БД
        }
 
        private void btn_Upd_Click(object sender, EventArgs e)
        {
            
        }
    }
}
загвоздка в том что я изменяю данные в таблице... кнопки добавить и удалить просто будут добавлять и удалять строки в датагриде, как же мне изменные данные кнопой btn_Upd(update, обновить) поместить в БД
пробовал чтото типа
C++
1
2
3
4
private void btn_Upd_Click(object sender, EventArgs e)
        {
            dataGridView1.Update(selectDataTable);
        }
но даже не понимаю как подобрать конструкцию. я бы мог сделать отдельную форму с текстбоксами и кнопкой типа "добавить данные" и в ней прописать запрос на добавление в БД. но там 20+ столбцов, поэтому табличку нужно редактировать в дата грид...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.05.2015, 19:47
Ответы с готовыми решениями:

Insert, Update, Delete
господа, проблема! реализовал удаление (Delete) что то примерно такое DataGridView.Rows.RemoveAt(i); OleDbCommand DeleteCommand...

DataGridView+SqlCeCommand+Insert,Update,Delete
Доброго времени суток всем! Помогите разобраться,добавляю в таб.через SqlCeCommand. SqlCeCommand command = new...

Сделать INSERT/DELETE/UPDATE таблиц
Необходимо сделать INSERT/DELETE/UPDATE таблиц, но у меня не получается :( есть datagrid без привязки к определенному источнику...

4
 Аватар для wm_leviathan
214 / 214 / 73
Регистрация: 12.01.2011
Сообщений: 767
25.05.2015, 21:07
грид все го лишь отображение dataSet'а. Зачем использовать datareader ?
используйте dataAdapter и и потом вызывайте update у него.

Добавлено через 5 минут
как пример:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
string connStr = "строка подключения к серверу";
            SqlDataAdapter dataAdapter = new SqlDataAdapter();
 
            string strSql = "SELECT * FROM GDP";
 
            DataTable tbl = new DataTable();
            
            SqlCommand command = new SqlCommand(strSql);
            
            SqlConnection con = new SqlConnection(connStr);
            
           con.Open();
           dataAdapter.SelectCommand = command;
           dataAdapter.SelectCommand.Connection = con;
           dataAdapter.SelectCommand = command;
           tbl.Locale = System.Globalization.CultureInfo.InvariantCulture;
           dataAdapter.Fill(tbl);
 
           dataGridView1.DataSource = tbl;//тут говорим гриду чтоб он показывал эту таблицу
а это позволит вносить изменения в базу:
C#
1
2
3
4
using (var cmdBuilder = new SqlCommandBuilder(dataAdapter))
           {
               dataAdapter.Update(tbl);
           }
2
6 / 6 / 1
Регистрация: 24.12.2012
Сообщений: 153
25.05.2015, 21:34  [ТС]
Спасибо, понял свою ошибку
0
 Аватар для wm_leviathan
214 / 214 / 73
Регистрация: 12.01.2011
Сообщений: 767
25.05.2015, 21:43
http://www.youtube.com/watch?v=_sB0A6FIhUM
вот кстати видюха по update из грида
0
6 / 6 / 1
Регистрация: 24.12.2012
Сообщений: 153
25.05.2015, 23:23  [ТС]
Цитата Сообщение от wm_leviathan Посмотреть сообщение
а это позволит вносить изменения в базу:
C#
1
2
3
4
using (var cmdBuilder = new SqlCommandBuilder(dataAdapter))
{
    dataAdapter.Update(tbl);
}
оу, а можно поподробней про эту часть кода? что с ней делать то?)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.05.2015, 23:23
Помогаю со студенческими работами здесь

Не работают команды Insert, Select, Update, Delete
oFgl71x1PX4 Тут все четко и понятно все компилируется ни каких ошибок, запускается, но как только я произвожу действия с базой нажимаю на...

Select, delete, update, insert. как писать?
Всем привет. Как дописать delete, update, insert. Поиск по форуму не дал результатов, а черз гугл не понимаю на чужих примерах. Если...

Insert, Update, Delete и две связанные таблицы
Доброе время суток. Помогите пожалуйста с таким вопросом. Есть в бд две таблицы(№1 с столбцами &quot;ID&quot;, &quot;Name&quot;,...

Не работает SELECT однако INSERT, UPDATE, DELETE работают
Здравствуйте! при написании программы столкнулся с такой проблемой: при попытке использования запроса SELECT проект просто не видит данные,...

Функция-интерпретатор в БД, для sql "select\insert\update\delete"
Нужно написать функцию-интерпретатор в БД, для sql &quot;select\insert\update\delete&quot;. Как бы движок на входе принимающий...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru