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

На загружает данные из таблицы MS SQL Server в DataGridView

01.05.2019, 17:33. Показов 723. Ответов 1

Студворк — интернет-сервис помощи студентам
Из приложения пытаюсь загрузить данные в таблицу DataGridView из базы данных SQL Server 2014. Собственно все работает, но только на таблицах у которых нет внешних ключей. Таблицы с внешними ключами не грузит. Делаю так:
На главной форме проекта:
C#
1
2
public static String conn_string = "Provider=SQLNCLI11;Data Source=CORE_I5\\SQLEXPRESS;Integrated Security=SSPI;Initial Catalog=dbSclad";
public static OleDbConnection connect = new OleDbConnection(conn_string);
На форме в которой таблица (это форма работает все загружается):
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
namespace store
{
    public partial class dolF : Form
    {
        public string CmdText = "SELECT * FROM dol";
        DataSet ds;
        OleDbDataAdapter dA;
        public dolF()
        {
            InitializeComponent();
            dA = new OleDbDataAdapter(CmdText, Form1.connect); 
            ds = new DataSet();
            dA.Fill(ds, "[dol]");
        }
 
        private void dolF_Load(object sender, EventArgs e)
        {
            if (Form1.connect.State == ConnectionState.Closed)
                Form1.connect.Open();
            bindingSource1.DataSource = ds.Tables[0];
            bindingNavigator1.BindingSource = bindingSource1;
            dataGridView1.DataSource = ds.Tables[0].DefaultView;
            //отключаем видимость первичного и внешних ключей
            dataGridView1.Columns[0].Visible = false;
            dataGridView1.Columns[1].HeaderText = "Наименование должности";
            dataGridView1.Columns[1].Width = 340;
        }
 
        private void dolF_FormClosed(object sender, FormClosedEventArgs e)
        {
            if (Form1.connect.State == ConnectionState.Open)
                Form1.connect.Close();
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            DialogResult result = MessageBox.Show(
                   "Сохранить изменения?",
                   "Сохранение данных в таблице",
                   MessageBoxButtons.OK,
                   MessageBoxIcon.Information,
                   MessageBoxDefaultButton.Button1,
                   MessageBoxOptions.DefaultDesktopOnly);
            if (result == DialogResult.OK)
            {
                OleDbCommandBuilder cb = new OleDbCommandBuilder(dA);
                dA.UpdateCommand = cb.GetUpdateCommand();
                dA.Update(ds.Tables[0]);
            }
        }
    }
}
А вот здесь не работает. Хотя в другом приложении точно такой же код для Access работал:
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
namespace store
{
    public partial class scladF : Form
    {
        public string CmdText = "SELECT * FROM sclad";
        public string CmdText2 = "SELECT * FROM sotr";
        DataSet ds;
        DataSet ds2;
        OleDbDataAdapter dA;
        OleDbDataAdapter dA2;
        public scladF()
        {
            InitializeComponent();
            dA = new OleDbDataAdapter(CmdText, Form1.connect); //Prev.connect - подключение с главной формы проекта
            dA2 = new OleDbDataAdapter(CmdText2, Form1.connect);
            ds = new DataSet();
            ds2 = new DataSet();
            dA.Fill(ds, "[sclad]");
            dA2.Fill(ds2, "[sotr]");
        }
 
        private void scladF_Load(object sender, EventArgs e)
        {
            if (Form1.connect.State == ConnectionState.Closed)
                Form1.connect.Open();
            bindingSource1.DataSource = ds.Tables[0];
            bindingNavigator1.BindingSource = bindingSource1;
            dataGridView1.DataSource = ds.Tables[0].DefaultView;
            //отключаем видимость первичного и внешних ключей
            dataGridView1.Columns[0].Visible = false;
            dataGridView1.Columns[1].HeaderText = "Наименование склада";
            dataGridView1.Columns[1].Width = 250;
            dataGridView1.Columns[2].HeaderText = "Адрес";
            dataGridView1.Columns[2].Width = 120;
            dataGridView1.Columns[3].HeaderText = "Телефон";
            dataGridView1.Columns[3].Width = 200;
            //первое подстановочное поле
            dataGridView1.Columns[4].Visible = false;
            DataGridViewComboBoxColumn DGVCMB = new DataGridViewComboBoxColumn();
            DGVCMB.DataPropertyName = "keysotr";
            DGVCMB.Name = "fiosotr";
            DGVCMB.HeaderText = "Заведующий";
            DGVCMB.Width = 200;
            DGVCMB.DataSource = ds2.Tables[0];
            DGVCMB.DisplayMember = "fio";
            DGVCMB.ValueMember = "keysotr";
            dataGridView1.Columns.Add(DGVCMB);
            dataGridView1.Columns[5].HeaderText = "Дата регистрации";
            dataGridView1.Columns[5].Width = 120;
        }
 
        private void scladF_FormClosed(object sender, FormClosedEventArgs e)
        {
            if (Form1.connect.State == ConnectionState.Open)
                Form1.connect.Close();
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            DialogResult result = MessageBox.Show(
                   "Сохранить изменения?",
                   "Сохранение данных в таблице",
                   MessageBoxButtons.OK,
                   MessageBoxIcon.Information,
                   MessageBoxDefaultButton.Button1,
                   MessageBoxOptions.DefaultDesktopOnly);
            if (result == DialogResult.OK)
            {
                OleDbCommandBuilder cb = new OleDbCommandBuilder(dA);
                dA.UpdateCommand = cb.GetUpdateCommand();
                dA.Update(ds.Tables[0]);
            }
        }
    }
}
Миниатюры
На загружает данные из таблицы MS SQL Server в DataGridView  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.05.2019, 17:33
Ответы с готовыми решениями:

Не получается обновить данные в БД SQL Server при изменении данных в dataGridView
ADO.NET C# Добавлено через 2 минуты using System; using System.Collections.Generic; using System.ComponentModel; using...

Как из EXcel прочитать данные из таблицы БД MS SQL SErver?
Как из EXcel прочитать данные из таблицы БД MS SQL SErver. ВОобще такое возможно?

В какой системной таблицы Sql Server хранит данные о пользователе?
Нужно при авторизации пользователя определить, в какой он роли находится. Нашла таблицу sys.sysusers, но там только ID и роль, но нет...

1
2 / 2 / 0
Регистрация: 10.04.2016
Сообщений: 73
01.05.2019, 17:41  [ТС]
Прикрепил скрин, что данные в таблице не отображаются

Добавлено через 6 минут
Меня интересует только обработчик загрузки формы:
C#
1
private void scladF_Load(object sender, EventArgs e)
Добавлено через 28 секунд
Кто-нибудь ПАМАГИТЕ!!! )))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.05.2019, 17:41
Помогаю со студенческими работами здесь

Как правильно передать данные из таблицы DataGridView в SQL базу данных
Здравствуйте. Есть таблица DataGridView которая содержит данный которые добавляет пользователь или загружает из файла. Как мне правильно...

Как программно вывести данные из таблицы базы ms sql на форму в dataGridView
Ребят, подскажите как программно вывести данные из таблицы базы ms sql на форму в dataGridView. Покажите пример на Visual C++ с...

Как с помощью MonthCalendar вывести в DataGridView с sql таблицы данные с определенной датой?
Всем доброго времени суток! Подскажите пожалуйста как с помощью MonthCalendar вывести в DataGridView с sql таблицы данные которые записаны...

Datagridview не загружает данные
Прошу Вашей помощи, гугл ответы дает, но не помогают они :) Создаем datagridview в него данные из mysql. datagridview заполняется...

Как настроить MS SQL Server, чтобы через Access, можно было редактировать таблицы MS SQL Server?
ВОПРОС: Как настроить MS SQL Server, чтобы через Access, можно было редактировать таблицы MS SQL Server? MS SQL Server...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru