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

Как вывести информацию из dataGridView в новую форму

03.06.2015, 09:27. Показов 2078. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. необходимо передать данные из dataGridView формы1 на форму2 в поля textBox и элемент listView. на форме1 в dataGridView отображается основная таблица, а на форме2 данные из подчиненных.
Код формы1
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
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.Collections;
 
namespace Сотрудники
{
    public partial class Form1 : Form
    {
DataAccessLayer dal = new DataAccessLayer();
        public Object i_N;
        Form2 frm2;
 
        public Form1()
        {
        frm2 = new Form2(this);
}
//заполняем данными таблицы Сотрудник dataGridView1
private void button1_Click(object sender, EventArgs e)
        {
            dataGridView1.DataSource = dal.GetAllTeacher();
        }
private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            i_N = dataGridView1.Rows[e.RowIndex].Cells[0].Value;
        }
//Открываем form2
private void button2_Click(object sender, EventArgs e)
        {
            frm2.ShowDialog();
        }
    }
}
Добавлено через 16 минут
Код Form2
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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace Сотрудники
{
    public partial class Form2 : Form
    {
        private Form1 frm;
        public Form2(Form1 f)
        {
            frm = f;
            InitializeComponent();
        }
        private void Form2_Load(object sender, EventArgs e)
        {
            string connectionString = @"Data Source=(local);Initial Catalog=СотрудникиБД;Integrated Security=True";
            SqlConnection conn = new SqlConnection(connectionString);
            SqlCommand cm = conn.CreateCommand();
            cm.CommandText = "Select * FROM Сотрудник LEFT JOIN 
Паспорт ON Сотрудник.КодСотрудника=Паспорт.КодСотрудника LEFT JOIN 
Контакты ON Сотрудник.КодСотрудника=Контакты.КодСотрудника
WHERE Сотрудник.КодСотрудника =" + frm.i_N;
conn.Open();
            SqlDataReader dr = cm.ExecuteReader();
            dr.Read();
            familytextBox.Text = dr["Фамилия"].ToString();
            nametextBox.Text = dr["Имя"].ToString();
            dateofBirthtextBox.Value = Convert.ToDateTime(dr["ДатаРождения"].ToString();
            registraciontextBox.Text = dr["Прописка"].ToString();
 
            dr.Close();
            conn.Close();
       }
    }
}
Как вывести поле "Телефон", в listView?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.06.2015, 09:27
Ответы с готовыми решениями:

При нажатии на одной из записи в первом DataGridView открыть новую форму с другим DataGridView
Здравствуйте,форумчане. Нужна Ваша помощь.Суть такова... у меня есть форма с DataGridView(список товаров) и есть вторая форма с др...

Как вывести информацию о созданном процессе в DatagridView
Как вывести информацию о созданном процессе в DatagridView?

Как вывести информацию на форму из обычной функции
Вопрос скорее для знатоков С++ но так так пишу приложение на Qt решил создать тему тут mainwindow.cpp #include...

6
 Аватар для wm_leviathan
214 / 214 / 73
Регистрация: 12.01.2011
Сообщений: 767
03.06.2015, 10:26
Лучший ответ Сообщение было отмечено DumoH19991 как решение

Решение

C#
1
ListViewItem newitem = new ListViewItem(dr["Прописка"].ToString());
C#
1
list1.Items.Add(newitem);
1
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 29
03.06.2015, 11:53  [ТС]
не подскажите как отобразить изображение из поля (типа image) dataGridView в pictureBox?
0
 Аватар для wm_leviathan
214 / 214 / 73
Регистрация: 12.01.2011
Сообщений: 767
03.06.2015, 12:19
C#
1
2
3
4
5
byte[] byteArray = new byte[0];
 byteArray = (byte[])reader["Image"];
 MemoryStream ms = new MemoryStream(byteArray);
 this.pictureBox1.Image = Image.FromStream(ms);
ms.Close();
1
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 29
03.06.2015, 20:54  [ТС]
1. В listBox отображается только 1 строка. Как отобразить все данные из подчиненной таблицы. т.е. у сотрудника несколько телефонных номеров, но отображается только 1 строка - 1 номер.
2. Если в dataGridView (Form1) в строке нет изображения и я пытаюсь открыть Form2, то появляется ошибка ' Не удалось привести тип объекта "System.DBNull" к типу "System.Byte[]" ' ссылается на
byteArray = (byte[])dr["Photo"];
0
 Аватар для wm_leviathan
214 / 214 / 73
Регистрация: 12.01.2011
Сообщений: 767
03.06.2015, 22:13
1) мог бы и сам по коду догадаться что там одна строка добавляется, учитесь проявлять стремление самому пытаться делать, а не ждать готового копипаста.
Code
1
2
3
4
5
while (dr.Read())
            {
ListViewItem newitem = new ListViewItem(dr["Прописка"].ToString());
list1.Items.Add(newitem);
}
2)не хочу гадать, не гадалкой же работаю. код показывайте как у вас происходит. скорее всего там просто if надо где то поставить, т.е. проверку на отсутствие картинки в текущей строке.
0
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 29
04.06.2015, 17:39  [ТС]
C#
1
2
3
4
5
while (dr.Read())
            {
ListViewItem newitem = new ListViewItem(dr["Прописка"].ToString());
list1.Items.Add(newitem);
}
все также выводит 1 строку.

код Form2:
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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace Сотрудники
{
    public partial class Form2 : Form
    {
        private Form1 frm;
        public Form2(Form1 f)
        {
            frm = f;
            InitializeComponent();
        }
        private void Form2_Load(object sender, EventArgs e)
        {
            string connectionString = @"Data Source=(local);Initial Catalog=СотрудникиБД;Integrated Security=True";
            SqlConnection conn = new SqlConnection(connectionString);
            SqlCommand cm = conn.CreateCommand();
            cm.CommandText = "Select * FROM Сотрудник LEFT JOIN 
Паспорт ON Сотрудник.КодСотрудника=Паспорт.КодСотрудника LEFT JOIN 
Контакты ON Сотрудник.КодСотрудника=Контакты.КодСотрудника
WHERE Сотрудник.КодСотрудника =" + frm.i_N;
conn.Open();
            SqlDataReader dr = cm.ExecuteReader();
            dr.Read();
            byte[] byteArray = new byte[0];
            byteArray = (byte[])reader["Photo"];  //ошибка при пустом значении ячейки
            MemoryStream ms = new MemoryStream(byteArray);
            this.pictureBox1.Image = Image.FromStream(ms);
            ms.Close();
            familytextBox.Text = dr["Фамилия"].ToString();
            nametextBox.Text = dr["Имя"].ToString();
            dateofBirthtextBox.Value = Convert.ToDateTime(dr["ДатаРождения"].ToString();
            registraciontextBox.Text = dr["Прописка"].ToString();
            while (dr.Read())
            {
                ListViewItem newitem = new ListViewItem(dr["Телефон"].ToString());
                listView1.Items.Add(newitem);
            }
            dr.Close();
            conn.Close();
       }
    }
}
Если в dataGridView расположенном на Form1 в ячейке Photo нет изображения, то выводит ошибку. Изображение загружаю так:
C#
1
2
3
4
5
6
private void button2_Click(object sender, EventArgs e)
{
    var ofd = new OpenFileDialog();
    if (ofd.ShowDialog() == DialogResult.OK)
    photoPictureBox.Image = Image.FromFile(ofd.FileName);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.06.2015, 17:39
Помогаю со студенческими работами здесь

Как правильно вывести информацию в DataGridView и сохранить изменения?
Никак не могу определиться, правильно ли я делаю или нет. Я в DGV вывожу информацию через представление. Понятно, что представление не...

Как при нажатии на pictureBox вывести в dataGridView информацию определенной строки
ребят, подскажите, как сделать правильно, чтобы при нажатии на pictureBox в dataGridView выводилась информация определенной строки

Как при выборе строки в DataGridView вывести информацию из связанных таблиц
Здравствуйте. Подскажите пожалуйста. Имеется база данных в которой находятся 5 связанных между собой таблиц. Имеется программа, в которой...

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

Как загружать на форму элементы управления, не создавая новую форму?
Здравствуйте, столкнулся с вопросом в visual studio c#, как загружать на форму элементы управления ( например, есть форма1 с кнопкой далее...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru