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

Выборка и группировка из двух datatable с последующим выводом в datagridview

14.12.2019, 15:19. Показов 1549. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день. Таков вопрос: при запуске приложения данные из БД подтягиваются в заранее созданные нетипизированный dataset и datatable. Нужно выводить общее количество продаж по каждому из сотрудников в DataGridView. Как можно произвести подобную операцию с помощью linq на datatable. Структура таблиц (названия таблиц полей в приложении и в бд идентичны) на изображениях ниже, как и код. В комментариях в коде - мои предыдущие попытки.
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
using System;
using System.Configuration;
using System.Data;
using System.Data.Common;
using System.Data.SqlClient;
using System.Windows.Forms;
 
namespace Task4
{
    public partial class Form1 : Form
    {
        readonly string _connStr;
        SqlDataAdapter Adapter { get; set; }
        IShopDB Shop { get; set; }
        public Form1()
        {
            Shop = new ShopDBDataContext();
            _connStr = ConfigurationManager.ConnectionStrings["DefaultConnStr"].ConnectionString;
            using(SqlConnection conn = new SqlConnection(_connStr))
            {
                try
                {
                    conn.Open();
                    Adapter = new SqlDataAdapter("select * from Products", conn);
                    Adapter.Fill(Shop.ShopDB, "Products");
 
                    Adapter = new SqlDataAdapter("select * from Employees", conn);
                    Adapter.Fill(Shop.ShopDB, "Employees");
 
                    Adapter = new SqlDataAdapter("select * from Customers", conn);
                    Adapter.Fill(Shop.ShopDB, "Customers");
 
                    Adapter = new SqlDataAdapter("select * from Orders", conn);
                    Adapter.Fill(Shop.ShopDB, "Orders");
                    
                    Adapter = new SqlDataAdapter("select * from OrderDetails", conn);
                    Adapter.Fill(Shop.ShopDB, "OrderDetails");
                    
                    Shop.ShopDB.EnforceConstraints = true;
                }
                catch(Exception ex)
                {
                    MessageBox.Show(ex.Message);
                    if (Shop.ShopDB.HasErrors)
                    {
                        foreach(DataTable dt in Shop.ShopDB.Tables)
                        {
                            if (dt.HasErrors)
                            {
                                MessageBox.Show(dt.TableName);
                                dt.GetErrors();
                            }
                        }
                    }
                }
                finally
                {
                    conn.Close();
                }
            }
            InitializeComponent();
        }
 
        private void Form1_Load(object sender, EventArgs e)
        {
            //var groupedOrders = (from orders in Shop.ShopDB.Tables["Orders"].AsEnumerable()
            //                     group orders by orders.Field<int>("EmployeeID") into g
            //                     select new
            //                     {
            //                         EmpID = g.Key,
            //                         SaleCount = g.Count()
            //                     }).ToList();
            //var empSales = from emp in Shop.ShopDB.Tables["Employees"].AsEnumerable()
            //               join order in Shop.ShopDB.Tables["Orders"].AsEnumerable()
            //               on emp.Field<int>("EmployeeID") equals order.Field<int>("EmployeeID")
            //               group emp by emp.Field<int>("EmployeeID");
            //List<DataRow> list = new List<DataRow>();
            //IEnumerable<IGrouping<int, DataRow>> groups = empSales.GroupBy(x => x.Key);
            //IEnumerable<DataRow> DataRows = empSales.SelectMany(group => group);
            //List<object[]> list= DataRows.Select(dr => dr.ItemArray).ToList();
            //var empss = DataRows.Select(d => new
            //{
            //    ID = d.Field<int>("EmployeeID"),
            //    Фамилия = d.Field<int>("Lname"),
            //    Имя = d.Field<int>("Fname"),
            //    Отчество = d.Field<int>("Mname")
 
            //});
 
            //var empSales = (from orders in Shop.ShopDB.Tables["Orders"].AsEnumerable()
            //                join emps in Shop.ShopDB.Tables["Orders"].AsEnumerable()
            //               on orders.Field<int>("EmployeeID") equals emps.Field<int>("EmployeeID")
            //               group orders by orders.Field<int>("EmployeeID")
            //               );
            //List<DataRow> list = new List<DataRow>();
            //IEnumerable<IGrouping<int, DataRow>> groups = empSales.GroupBy(x => x.Key);
            //IEnumerable<DataRow> DataRows = empSales.SelectMany(group => group);
            //List<DataRow> newList = DataRows.ToList();
            //var empSales = (from emps in Shop.ShopDB.Tables["Employees"].AsEnumerable()
            //                join g in groupedOrders on emps.Field<int>("EmployeeID") equals g.EmpID
            //                select new
            //                {
            //                    Фамилия = emps.Field<int>("Lname"),
            //                    Имя = emps.Field<int>("Fname"),
            //                    Отчество = emps.Field<int>("Mname"),
            //                    Продажи = g.SaleCount
            //                });
            //var empSales = (from orders in Shop.ShopDB.Tables["Orders"].AsEnumerable()
            //                group orders by orders.Field<int>("EmployeeID") into g
            //                join emps in Shop.ShopDB.Tables["Employees"].AsEnumerable()
            //                on g.Key equals emps.Field<int>("EmployeeID")
            //                select new
            //                {
            //                    Фамилия = emps.Field<int>("Lname"),
            //                    Имя = emps.Field<int>("Fname"),
            //                    Отчество = emps.Field<int>("Mname"),
            //                    Продажи = g.Count()
            //                });
 
            //EmployeesSalesGridView.DataSource = dt;
            //EmployeesSalesGridView.DataSource = list;
        }
    }
}
Миниатюры
Выборка и группировка из двух datatable с последующим выводом в datagridview   Выборка и группировка из двух datatable с последующим выводом в datagridview  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.12.2019, 15:19
Ответы с готовыми решениями:

Выборка всех данных с последующим выводом через Ajax
Добрый день. Подскажите как вывести все данные из выборки в AJAX. Код для вывода данных: var ViewModel = function () { var...

Загрузить данные из БД в DataTable с последующим выводом в DGV
помогите пожалуйста ;) мне нужна чтобы из база данных перенести информацию в datatable а потом отображать эту информацию в dataGridview...

Поиск по DataTable с выводом в dataGridView
Подскажите, как вывести строки из DataTable в dataGridView с помощью поиска Допустим, я делаю запрос в базу данных В DataTable...

4
 Аватар для Рядовой
1524 / 914 / 329
Регистрация: 17.05.2015
Сообщений: 3,438
15.12.2019, 21:20
SteelWing_RC, сделать запрос в sql и не заниматься ерундой
0
1 / 1 / 0
Регистрация: 12.10.2018
Сообщений: 24
15.12.2019, 22:01  [ТС]
Задание требует
Цитата Сообщение от Рядовой Посмотреть сообщение
сделать запрос в sql и не заниматься ерундой
Да и правильный вариант уже есть:
C#
1
2
3
4
5
6
7
8
9
10
11
var empSales = from emp in Shop.ShopDB.Tables["Employees"].AsEnumerable()
                           join order in Shop.ShopDB.Tables["Orders"].AsEnumerable()
                           on emp.Field<int>("EmployeeID") equals order.Field<int>("EmployeeID")
                           group emp by emp.Field<int>("EmployeeID") into g
                           select new
                           {
                               EmployeeID = g.Key,
                               FullName = string.Join(" ", g.First().Field<string>("LName"), g.First().Field<string>("FName"), g.First().Field<string>("MName")),
                               SalesNumber = g.Count()
                           };
EmployeesSalesGridView.DataSource = empSales.ToList();
0
Эксперт .NET
 Аватар для Usaga
14315 / 9401 / 1355
Регистрация: 21.01.2016
Сообщений: 35,455
16.12.2019, 02:48
Цитата Сообщение от SteelWing_RC Посмотреть сообщение
Да и правильный вариант уже есть:
Это не правильный вариант, а занятие ерундой. Данные в нужном виде нужно сразу из базы вытаскивать.
0
 Аватар для Aferuga
645 / 529 / 324
Регистрация: 20.05.2015
Сообщений: 1,471
18.12.2019, 06:35
Я не понял на фига на лету формировать DataContext, добавьте в обозревателе решений "классы linq to sql", задайте там нужные таблицы, а потом юзайте в нужных местах программы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.12.2019, 06:35
Помогаю со студенческими работами здесь

Выборка из двух таблиц в одину DataTable mySQL
Всем привет! есть два запроса, Выбрать юзеров public DataTable SelectUsersTable() { string sql...

Поиск значения с последующим выводом
Помогите ламеру в php. Суть такая. Нужно организовать поиск по указанным значениям с последующим выводом найденного значения...

Поиск значения с последующим выводом
Есть код, который работает, но маленький недостаток . В БД хранятся номера в которых может присутствовать лидирующий 0, а может и не...

Группировка и суммирование datatable
Всем привет. Как можно выбрать данные из datatable, аналогично sql запросу &quot;&quot;SELECT Поле1, AVG(Поле2) FROM &quot; На выходе...

Группировка данных в DataTable
Добрый день! Помогите, пожалуйста, разобраться с запросом LINQ. Может я вообще использую не тот инструмент. Цель: сколько...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru