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

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

13.04.2022, 18:18. Показов 904. Ответов 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 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru