0 / 0 / 0
Регистрация: 02.12.2020
Сообщений: 4

Как добавить картинку в dataGridView?

13.04.2022, 18:18. Показов 912. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем, доброго времени суток)) Очень прошу помогите!!!

У меня есть datagridview(данные в ней из БД SQL), а так же 6 textbox' и кнопка добавить на форме. Подскажете как добавить картинку в столбцы тоб Фотография и Документы. и чтобы они загрузились БД в в таб Преподаватели

Побывала через pictureBox и две кнопки: Загрузить фото для загрузки фото в pictureBox1 и кнопка Добавить фото в таблицу. Вылизала Ошибка Что нельзя программно добавить строки в datagridview если он перевязан к данным.

Во вложениях вид формы и БД в Microsoft SQL Server Management Studio 18
Очень, очень прошу помощи!!

Код всей формы

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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
 
namespace Школа_робототехники
{
    public partial class FormInfoTeacher : Form
    {
        string ConnStr = @"Data Source=DESKTOP-2HBUDMQ;Initial Catalog=Школа_робототехники;Integrated Security=True";
 
        public FormInfoTeacher()
        {
            InitializeComponent();
        }
 
       
        public void FillTeachers()
        {
            string SqlText = "SELECT * FROM [Преподаватели]";
            SqlDataAdapter da = new SqlDataAdapter(SqlText, ConnStr);
            DataSet ds = new DataSet();
            da.Fill(ds, "[Преподаватели]");
            dataGridView1.DataSource = ds.Tables["[Преподаватели]"].DefaultView;
        }
 
        private void FormInfoTeacher_Load(object sender, EventArgs e)
        {
            FillTeachers();
 
           
        }
 
        private void ВuttonDobavit_Click(object sender, EventArgs e)
        {
 
            SqlConnection con = new SqlConnection(ConnStr);
            // Выполняем запрос к базе данных
            con.Open();//открываем соединение
            string SqlText = "INSERT INTO [Преподаватели] ([Код_преподавателя],[ФИО],[Фотография],[Дата_рождения],[Документы],[Код_группы])" + " VALUES(@Код_преподавателя, @ФИО, @Фотография, @Дата_рождения, @Документы, @Код_группы)";
            SqlCommand dbCommand = new SqlCommand(SqlText, con);//команда
            dbCommand.Parameters.AddWithValue("@Код_преподавателя", textBox1.Text);
            dbCommand.Parameters.AddWithValue("@ФИО", textBox2.Text);
            dbCommand.Parameters.AddWithValue("@Фотография", textBox3.Text);
            dbCommand.Parameters.AddWithValue("@Дата_рождения", textBox4.Text);
            dbCommand.Parameters.AddWithValue("@Документы", textBox5.Text);
            dbCommand.Parameters.AddWithValue("@Код_группы", textBox6.Text);
 
 
            if (dbCommand.ExecuteNonQuery() != 1)
 
                MessageBox.Show("Ошибка выполнения запроса! Данные не добавлены!", "Ошибка!", MessageBoxButtons.OK, MessageBoxIcon.Error);
 
            else
 
                MessageBox.Show("Данные добавлены!", "Сообщение!", MessageBoxButtons.OK);
            FillTeachers();
 
            //очистка данных из тест полей
            textBox1.Clear();
            textBox2.Clear();
            textBox3.Clear();
            textBox4.Clear();
            textBox5.Clear();
            textBox6.Clear();
        }
 
 
 
        private void ButtonDelete_Click(object sender, EventArgs e)
        {
            //Проверяем количество выбранных строк
            if (dataGridView1.SelectedRows.Count != 1)
            {
                MessageBox.Show("Выберите одну строку для удаления!", "Сообщение!", MessageBoxButtons.OK);
                return;
            }
            // Запомним выбранную строку
            int index = dataGridView1.SelectedRows[0].Index;
 
            //Проверим данные в таблице
            if (dataGridView1.Rows[index].Cells[0].Value == null)
            {
                MessageBox.Show("Не все данные введены!", "Сообщение!", MessageBoxButtons.OK);
                return;
            }
 
            //Считаем данные
            string id = dataGridView1.Rows[index].Cells[0].Value.ToString();
 
            SqlConnection con = new SqlConnection(ConnStr);
            // Выполняем запрос к базе данных
            con.Open();//открываем соединение
            string SqlText = "DELETE FROM [Преподаватели] WHERE Код_преподавателя=" + id;//строка запроса
            SqlCommand dbCommand = new SqlCommand(SqlText, con);//команда
 
            //Выполняем запрос
            if (dbCommand.ExecuteNonQuery() != 1)
 
                MessageBox.Show("Ошибка выполнения запроса!", "Ошибка!", MessageBoxButtons.OK, MessageBoxIcon.Error);
            else
                MessageBox.Show("Данные удалены!", "Сообщение!", MessageBoxButtons.OK);
            // Удаляем данные из таблицы в форме
 
            dataGridView1.Rows.RemoveAt(index);
            con.Close();
        }
 
// Кнопка загрузки фото pictureBox
        private void BtnBrowseImage_Click(object sender, EventArgs e)
        {
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.Filter = "Файлы изображений (*.BPM;*.JPG; *.PNG; *.GIF; )|*.BPM;*.JPG; *.PNG; *.GIF;|Все файлы (*.*)|*.*";
            if (ofd.ShowDialog() == DialogResult.OK)
            {
                try
                {
                    pictureBox1.Image = new Bitmap(ofd.FileName);
                }
                catch
                {
                    MessageBox.Show("Невозможно открыть выбранный файл", "Ошибка!", MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
            }
        }
//Кнопка Добавить фото в табл
        private void BtnAdd_Click(object sender, EventArgs e)
        {
            try
            {
                MemoryStream ms = new MemoryStream();
                pictureBox1.Image.Save(ms, pictureBox1.Image.RawFormat);
                byte[] img = ms.ToArray();
                dataGridView1.Rows.Add(textBox6.Text, img);
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
 
 
    }
}
Миниатюры
Как добавить картинку в dataGridView?   Как добавить картинку в dataGridView?  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.04.2022, 18:18
Ответы с готовыми решениями:

Как добавить картинку в dataGridView?
Делаю что-то вроде новостного агрегатора. Работаю с newsapi. org. вопрос заключается в следующем: как вытащить картинки, ссылки на которые...

Как на макете печатной формы добавить картинку после чего добавить реквизиты на эту картинку
Объясните пожалуйста как на макете печатной формы добавить картинку после чего добавить реквизиты на эту картинку из запроса?

Как добавить картинку на картинку?
Доброго времени суток. Решил создать доску объявлений на WP, установил плагин WPAdverts, и задался мыслю сделать как у олх...

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

Как добавить "картинку на картинку" при наведении?
Нужно сделать так как на этом сайте - http://www.break.com/ - не удаляйте ссылку не раклама При наведении на картинку появляется...

Как отобразить в datagridview картинку из varbinary?
Допустим в датагридвью три столбца. _________________________ |Тип | Имя файла | varbinary| ````````````````````````` ...

Как вставить картинку в ячейку DataGridView
Имею DataGridView, большее кол-во ячеек пустых, в некоторых содержаться цифры. Хотелось бы заменить ячейки с цифрами на ячейки с...

Как вывести картинку из datagridview по клику
У меня есть код: private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e) { ...

Как добавить картинку?
Привет! Создаю сайт на dle, и возникла такая проблема. Новость у меня устроена таким образом, (т.е файлы short-story и full-story): ...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru