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

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

14.12.2019, 15:19. Показов 1529. Ответов 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
14114 / 9331 / 1350
Регистрация: 21.01.2016
Сообщений: 35,067
16.12.2019, 02:48
Цитата Сообщение от SteelWing_RC Посмотреть сообщение
Да и правильный вариант уже есть:
Это не правильный вариант, а занятие ерундой. Данные в нужном виде нужно сразу из базы вытаскивать.
0
 Аватар для Aferuga
644 / 528 / 324
Регистрация: 20.05.2015
Сообщений: 1,469
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
Ответ Создать тему
Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru