Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552

Данные двух запросов в один datagrid

28.03.2018, 10:05. Показов 1283. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день не могли бы подсказать как вывести данные из двух таблиц в один datagrid.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
SqlDataAdapter sqlDataAdapter = new SqlDataAdapter("SELECT TOP 100 * FROM [MexKIZ] WHERE CONCAT(ProductName,' ',kiz) LIKE N'%" + textBox1.Text + "%' ", Connection);
                DataTable dataTable = new DataTable();
                sqlDataAdapter.Fill(dataTable);
                dataGridView2.DataSource = dataTable;
                    dataGridView2.Columns[0].Visible = false;
                    dataGridView2.Columns[1].Visible = false;
                    dataGridView2.Columns[3].Visible = false;
                    dataGridView2.Columns[2].HeaderText = "КОД ТОВАРА";
                    dataGridView2.Columns[2].Width = dataGridView2.Width / 100 * 30;
                    dataGridView2.Columns[11].HeaderText = "НАИМЕНОВАНИЕ";
                    dataGridView2.Columns[11].Width = dataGridView2.Width / 100 * 75;
                    dataGridView2.Columns[5].Visible = false;
                    dataGridView2.Columns[6].Visible = false;
                    dataGridView2.Columns[7].Visible = false;
                    dataGridView2.Columns[8].Visible = false;
                    dataGridView2.Columns[9].Visible = false;
                    dataGridView2.Columns[10].Visible = false;
                    dataGridView2.Columns[4].Visible = false;
                    dataGridView2.Columns[12].Visible = false;
Этот код выводит данные, но есть вторая таблица и её данные надо добавить в тот же datagrid.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.03.2018, 10:05
Ответы с готовыми решениями:

Вывести результат двух запросов в один DataGrid
У меня есть два запроса, в первом я ищу свободные комнаты в гостинице(смотрю не была ли комната где-либо зарегистрирована), во втором...

Из двух запросов получить один
Подскажите как составить запрос в SQL. Надо сначала найти все записи с значением 1 в поле ID_USERS затем из этих записей выбрать одну у...

Объединение двух запросов в один
Есть два запроса которые по отдельности работают нормально. У этих двух запрос есть общая таблица xxx_content. Подскажите как их правильно...

14
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 10:19
menafis, ужасный говнокодище.

Вы можете словами описать, что хотели сделать?
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 10:23  [ТС]
Usaga, код не мой, как не странно, надо из двух таблиц выводились данные в один datagrid.
0
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 10:30
menafis, да хоть двадцать таблиц. Запрашивайте данные в виде одной выборки, в виде одного DataTable. Не надо колонки трогать в контроле. Просто в DataSource присвойте объект с данными и позвольте контролу самому сгенерировать все колонки (или сами задайте в дизайнере, если знаете заранее, что и как).
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 10:34  [ТС]
Usaga, спасибо

Добавлено через 1 минуту
Usaga, так имеете в виду
C#
1
2
3
4
 SqlDataAdapter sqlDataAdapter = new SqlDataAdapter("SELECT TOP 100 * FROM [MexKIZ],[ExcelDB] WHERE CONCAT(ProductName,' ',kiz) LIKE N'%" + textBox1.Text + "%'  ", Connection);
                DataTable dataTable = new DataTable();
                sqlDataAdapter.Fill(dataTable);
                dataGridView2.DataSource = dataTable;
0
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 10:37
menafis, это декартово произведение из двух таблиц, вы уверены, что это то, чего вы хотите? Но идея верная: получаете из базы сразу нужные данные и просто скармливаете контролу.
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 10:39  [ТС]
Usaga, понятно только в в таблица столбы различны, то есть то что указано в WHERE есть только в таблицы MEX. Как тут быть.
0
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 10:43
menafis, я не понял смысла сказанного. Рекомендую потратить немного времени на изучение примеров использования оператора JOIN, а то сдаётся мне, что у вас всё плохо с SQL.
1
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 11:19  [ТС]
Usaga, не так чтоб очень плохо с SQL, но и не фонтан. Серединка где-то.

Добавлено через 6 минут
Usaga,
C#
1
SqlDataAdapter sqlDataAdapter = new SqlDataAdapter("SELECT  * FROM [MexKIZ] FULL JOIN [ExcelDB] ON [MexKIZ].ProductName=[ExcelDB].name  WHERE CONCAT(ProductName,' ',kiz) LIKE N'%" + textBox1.Text + "%' ", Connection);
вот запрос, как я поянл join привязывает столбец из одной таблицы к столбцу с другой таблицы.

Добавлено через 14 минут
Usaga, я наверно не так немного описал саму задачу, это код для своеобразного поиска то таблицы [MexKIZ]
C#
1
2
3
4
SqlDataAdapter sqlDataAdapter = new SqlDataAdapter("SELECT TOP 100 * FROM [MexKIZ]  WHERE CONCAT(ProductName,' ',kiz) LIKE N'%" + textBox1.Text + "%' ", Connection);
                DataTable dataTable = new DataTable();
                sqlDataAdapter.Fill(dataTable);
                dataGridView2.DataSource = dataTable;
Но у нас есть еще одна таблица которая имеет свои поля, вот аналогия для неё
C#
1
2
3
4
 SqlDataAdapter sqlDataAdapter = new SqlDataAdapter("SELECT TOP 100 * FROM [ExcelDB] WHERE CONCAT(code,' ',name) LIKE N'%" + textBox1.Text + "%' ", Connection);
            //    DataTable dataTable = new DataTable();
            //    sqlDataAdapter.Fill(dataTable);
            //    dataGridView2.DataSource = dataTable;
. Задача в том чтоб делать поиск и по той и по той таблице.

Добавлено через 3 минуты
Usaga, а у нас подгрузка идет либо из той таблицы либо из той
0
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 11:39
Цитата Сообщение от menafis Посмотреть сообщение
а у нас подгрузка идет либо из той таблицы либо из той
Что это должно означать?

Вам нужно сджойнить две таблицы, в условии указать критерии. Эти критерии будут распространяться на обе таблицы в джойне (если вы правильно критерии укажите).

Не используйте конкатенацию для формирования запросов, так только нубы полные делают. Для этого есть SqlCommand и SqlParameter.

Добавлено через 3 минуты
menafis, я вам настоятельно рекомендую отложить ваше приложение и подключившись к вашей базе напрямую, повыполнять интересующие вас запросы. А так тыканье наугад получается.
1
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 12:22  [ТС]
Usaga, разобрался, что делал не так, спасибо за указание на join

Добавлено через 19 минут
вот конечный результат
C#
1
2
3
4
SqlDataAdapter sqlDataAdapter = new SqlDataAdapter("SELECT * FROM [MexKIZ] FULL JOIN [ExcelDB] ON [MexKIZ].kiz = [ExcelDB].code  WHERE CONCAT([MexKIZ].ProductName,' ',[MexKIZ].kiz,'',[ExcelDB].code) LIKE N'%" + textBox1.Text + "%' ", Connection);
                DataTable dataTable = new DataTable();
                sqlDataAdapter.Fill(dataTable);
                dataGridView2.DataSource = dataTable;
Добавлено через 18 минут
Usaga, теперь он у нас все выдает в своих колонках, скажите а можно чтоб колонки были общие для двух таблиц. То есть чтоб колонка например name из одной таблицы писала в себя name другой таблицы.
0
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 12:25
menafis, да, так можно, но тогда количество колонок, их типы и имена должны строго совпадать в выборке, а саму выборку составить из двух с помощью оператора UNION.
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 12:28  [ТС]
Usaga, ок понял то есть два select через UNION
0
Эксперт .NET
 Аватар для Usaga
14086 / 9303 / 1348
Регистрация: 21.01.2016
Сообщений: 34,922
28.03.2018, 12:34
menafis, да.

Добавлено через 2 минуты
Имена полей нужно будет насильно приводить в одном из Select-ов к именам полей в другом.
0
3 / 3 / 2
Регистрация: 26.02.2014
Сообщений: 552
28.03.2018, 12:39  [ТС]
Usaga, спасибо понял, выручаете меня в который раз.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.03.2018, 12:39
Помогаю со студенческими работами здесь

Свод двух запросов в один (Access)
есть 2 запроса с 15 столбацами (и там, и там). Разница в том, что существуют некие условия и различия. не все так просто... Аксес...

Из двух идентичных запросов работает один
Всем привет. Вот у меня есть такое: <tr> <td>Организация, в которой состоит на учете</td> <td> <select...

Обьединение двух JPQL запросов в один
Добрый день! Есть задание: Вывести информацию о планетах и их спутниках, имеющих наименьший радиус и наибольшее количество спутников. Я...

Выгрузка двух таблиц в один datagrid
Всем привет! Пытаюсь выгрузить две таблицы в один datagrid (значения из одно таблицы должны идти под значением из другой при равных...

Как из двух запросов сделать один вложенный
Вот есть два запросы,помогите сделать вложенный. SELECT CONCAT(customer_name," ",Surname) as...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
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