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

Как оптимизировать код DataGridView (SQLite)?

25.01.2018, 04:11. Показов 786. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вопрос в том,как из этого говно кода сделать,чтото похожее на нормальную реализацию
Принцип работы такой
Подключаемся к файлу базы с помощью SQlite
ВЫтягиваем данные оттуда и впихиваем в datagridview
Теперь переименовываем в читабельные столбцы
Не нужные ячейки для глаз пользователя скрываем
Меняем ширину нужных ячеек
И нужные мне ячейки закрашиваем цветами зеленый,красный,желтый

ВОПРОС!
Как сделать,так,чтобы каждый раз через Таймер снова и снова не запускать вот этот весь код,но при этом обновлять данные из базы (ЭТО КОД ИЗ ПАРСЕРА,КОТОРЫЙ ПАРСИТ каждые 30сек)
Как сделать,чтобы каждый раз не запускать Переименовывание столбцов,ширину,
А только менять содерживое их
Не пойму как оптимизировать это ДЕЛо

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
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
        public void refresh()
        {
            try
            {
                Connection.Open();
                adapter = new SQLiteDataAdapter("SELECT * FROM match_v ORDER BY st ASC LIMIT 200", Connection);
                bulding = new SQLiteCommandBuilder(adapter);
                dataset = new DataSet();
                adapter.Fill(dataset, "match_v");
                adapter.TableMappings.Add("match_v", "match_v");
                dataGridView2.DataSource = dataset.Tables[0];
 
 
                dataGridView2.Columns["team1"].HeaderText = "Дома";
                dataGridView2.Columns["team2"].HeaderText = "Гости";
                dataGridView2.Columns["champ"].HeaderText = "Чемпионат";
                dataGridView2.Columns["result"].HeaderText = " =";
                dataGridView2.Columns["date_now"].HeaderText = "Время";
 
                dataGridView2.Columns["score1"].HeaderText = "Итог1";
                dataGridView2.Columns["score2"].HeaderText = "Итог2";
                dataGridView2.Columns["score3"].HeaderText = "Итог3";
                dataGridView2.Columns["score4"].HeaderText = "Итог4";
                dataGridView2.Columns["score5"].HeaderText = "Итог5";
 
                dataGridView2.Columns["fora_m"].HeaderText = "Фора1";
                dataGridView2.Columns["fora_b"].HeaderText = "Фора2";
                dataGridView2.Columns["total_m"].HeaderText = "Меньше";
                dataGridView2.Columns["total_b"].HeaderText = "Больше";
 
                dataGridView2.Columns["for2"].HeaderText = "2set Ф1";
                dataGridView2.Columns["for3"].HeaderText = "3set Ф2";
                dataGridView2.Columns["for6"].HeaderText = "3set Ф3";
                dataGridView2.Columns["for4"].HeaderText = "4set Ф4";
                dataGridView2.Columns["for5"].HeaderText = "4set Ф5";
 
                dataGridView2.Columns["st"].HeaderText = "Статус";
 
 
 
 
                //dataGridView2.Columns["date"].Visible = false;
                //dataGridView2.Columns["st_5"].Visible = false;
                //dataGridView2.Columns["st_1"].Visible = false;
                //dataGridView2.Columns["st_2"].Visible = false;
                //dataGridView2.Columns["st_3"].Visible = false;
                //dataGridView2.Columns["st_4"].Visible = false;
                //dataGridView2.Columns["date_stat"].Visible = false;
                //dataGridView2.Columns["pr2"].Visible = false;
                //dataGridView2.Columns["pr3"].Visible = false;
                //dataGridView2.Columns["pr4"].Visible = false;
                //dataGridView2.Columns["pr5"].Visible = false;
                //dataGridView2.Columns["pr6"].Visible = false;
                //dataGridView2.Columns["team1"].Visible = false;
 
                dataGridView2.Columns[1].Width = 165;
                dataGridView2.Columns[2].Width = 140;
                dataGridView2.Columns[3].Width = 140;
 
                dataGridView2.Columns[4].Width = 50;
                dataGridView2.Columns[5].Width = 50;
                dataGridView2.Columns[6].Width = 50;
                dataGridView2.Columns[7].Width = 50;
                dataGridView2.Columns[8].Width = 50;
 
                dataGridView2.Columns[9].Width = 30;
                dataGridView2.Columns[15].Width = 70;
                dataGridView2.Columns[20].Width = 45;
 
                dataGridView2.Columns[15].DisplayIndex = 10;
                dataGridView2.Columns[22].DisplayIndex = 15;
                dataGridView2.Columns[13].DisplayIndex = 16;
                dataGridView2.Columns[14].DisplayIndex = 17;
                dataGridView2.Columns[20].DisplayIndex = 1;
 
                for (int i = 0; i < dataGridView2.RowCount; i++)
                {
                        switch (dataGridView2.Rows[i].Cells[16].Value.ToString())
                        {
                            case "+":
                                if (dataGridView2.Rows[i].Cells[11].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[11].Style.BackColor = Color.Green;
                                    dataGridView2.Rows[i].Cells[11].Style.ForeColor = Color.White;
                                }
                                break;
                            case "-":
                                if (dataGridView2.Rows[i].Cells[11].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[11].Style.BackColor = Color.Red;
                                    dataGridView2.Rows[i].Cells[11].Style.ForeColor = Color.White;
                                }
                                break;
                            case "0":
                                if (dataGridView2.Rows[i].Cells[11].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[11].Style.BackColor = Color.Yellow;
                                }
                                break;
 
                        }
 
                        switch (dataGridView2.Rows[i].Cells[17].Value.ToString())
                        {
                            case "+":
                                if (dataGridView2.Rows[i].Cells[12].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[12].Style.BackColor = Color.Green;
                                    dataGridView2.Rows[i].Cells[12].Style.ForeColor = Color.White;
                                }
                                break;
                            case "-":
                                if (dataGridView2.Rows[i].Cells[12].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[12].Style.BackColor = Color.Red;
                                    dataGridView2.Rows[i].Cells[12].Style.ForeColor = Color.White;
                                }
                                break;
                            case "0":
                                if (dataGridView2.Rows[i].Cells[12].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[12].Style.BackColor = Color.Yellow;
                                }
                                break;
 
                        }
                        switch (dataGridView2.Rows[i].Cells[18].Value.ToString())
                        {
                            case "+":
                                if (dataGridView2.Rows[i].Cells[13].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[13].Style.BackColor = Color.Green;
                                    dataGridView2.Rows[i].Cells[13].Style.ForeColor = Color.White;
                                }
                                break;
                            case "-":
                                if (dataGridView2.Rows[i].Cells[13].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[13].Style.BackColor = Color.Red;
                                    dataGridView2.Rows[i].Cells[13].Style.ForeColor = Color.White;
                                }
                                break;
                            case "0":
                                if (dataGridView2.Rows[i].Cells[13].Value.ToString() != " ")
                                {
                                    dataGridView2.Rows[i].Cells[13].Style.BackColor = Color.Yellow;
                                }
                                break;
 
                        }
 
                    switch (dataGridView2.Rows[i].Cells[19].Value.ToString())
                    {
                        case "+":
                            if (dataGridView2.Rows[i].Cells[14].Value.ToString() != " ")
                            {
                                dataGridView2.Rows[i].Cells[14].Style.BackColor = Color.Green;
                                dataGridView2.Rows[i].Cells[14].Style.ForeColor = Color.White;
                            }
                            break;
                        case "-":
                            if (dataGridView2.Rows[i].Cells[14].Value.ToString() != " ")
                            {
                                dataGridView2.Rows[i].Cells[14].Style.BackColor = Color.Red;
                                dataGridView2.Rows[i].Cells[14].Style.ForeColor = Color.White;
                            }
                            break;
                        case "0":
                            if (dataGridView2.Rows[i].Cells[14].Value.ToString() != " ")
                            {
                                dataGridView2.Rows[i].Cells[14].Style.BackColor = Color.Yellow;
                            }
                            break;
 
                    }
 
                    switch (dataGridView2.Rows[i].Cells[23].Value.ToString())
                    {
                        case "+":
                            if (dataGridView2.Rows[i].Cells[22].Value.ToString() != " ")
                            {
                                dataGridView2.Rows[i].Cells[22].Style.BackColor = Color.Green;
                                dataGridView2.Rows[i].Cells[22].Style.ForeColor = Color.White;
                            }
                            break;
                        case "-":
                            if (dataGridView2.Rows[i].Cells[22].Value.ToString() != " ")
                            {
                                dataGridView2.Rows[i].Cells[22].Style.BackColor = Color.Red;
                                dataGridView2.Rows[i].Cells[22].Style.ForeColor = Color.White;
                            }
                            break;
                        case "0":
                            if (dataGridView2.Rows[i].Cells[22].Value.ToString() != " ")
                            {
                                dataGridView2.Rows[i].Cells[22].Style.BackColor = Color.Yellow;
                            }
                            break;
 
                    }
 
 
                }
 
                             
            }
            catch (SQLiteException ex)
            {
                MessageBox.Show(ex.Message, "Ошибка",
    MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            finally
            {
                Connection.Close();
            }
 
 
        }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.01.2018, 04:11
Ответы с готовыми решениями:

Как оптимизировать работу с несколькими DataGridView?
Есть форма с несколькими DataGridView (отсюда https://www.cyberforum.ru/csharp-net/thread228350.html). По клику в заголовке нужно...

Как работать с БД SQLite и с DataGridView?
Есть БД на SQLite нужно вывести данные с таблиц на DataGridView. Как это реализовать? И какие отличия между SQLite и MySQL?

Оптимизировать код. взаимодействие с sqlite
имею два запроса: рабочий вариант. type_tech = request.query.get('type_tech', '').decode('utf-8') where = ' WHERE name =...

3
 Аватар для Aferuga
644 / 528 / 324
Регистрация: 20.05.2015
Сообщений: 1,469
25.01.2018, 08:07
Цитата Сообщение от ProRight Посмотреть сообщение
Теперь переименовываем в читабельные столбцы
Не нужные ячейки для глаз пользователя скрываем
Меняем ширину нужных ячеек
Создаем столбцы в гриде и прописываем им всем свойство DataPropertyName в зависимости от имен столбцов в БД и остальные настройки. Как вариант сделать как-то так :
Кликните здесь для просмотра всего текста
C#
1
2
3
4
5
6
7
8
9
//при первичной загрузке
            bs = new BindingSource(); //лучше сделать глобальным для формы как и адаптер
            bs.DataSource=dataset;
            bs.DataMember =  dataset.Tables[0].TableName;
dataGridView2.DataSource = bs;
//.............
//при обновлении
 adapter.Fill(dataset, "match_v");
bs.ResetBindings(true);

Цитата Сообщение от ProRight Посмотреть сообщение
И нужные мне ячейки закрашиваем цветами зеленый,красный,желтый
Можно как-то так:
Кликните здесь для просмотра всего текста
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
        private void dataGridView2_CellPainting(object sender, DataGridViewCellPaintingEventArgs e)
        {
             int[] ind= new int[5] {11,12,13,14,22} ;
             if (ind.Contains(e.ColumnIndex)){      
              int check_col = (e.ColumnIndex>20?23:e.ColumnIndex+5);
                        switch (dataGridView2.Rows[e.RowIndex].Cells[check_col].Value.ToString())
                        {
                            case "+":
                                if (e.Value.ToString() != " ")
                                {
                                    e.CellStyle.BackColor = Color.Green;
                                    e.CellStyle.ForeColor = Color.White;
                                }
                                break;
                            case "-":
                                if (e.Value.ToString() != " ")
                                {
                                   e.CellStyle.BackColor = Color.Red;
                                    e.CellStyle.ForeColor = Color.White;
                                }
                                break;
                            case "0":
                                if (e.Value.ToString() != " ")
                                {
                                    e.CellStyle.BackColor = Color.Yellow;
                                }
                                break;
 
                        }
}
        }
0
0 / 0 / 0
Регистрация: 14.01.2018
Сообщений: 14
25.01.2018, 16:17  [ТС]
Aferuga, что такое bs. Где взялось?
0
 Аватар для Aferuga
644 / 528 / 324
Регистрация: 20.05.2015
Сообщений: 1,469
26.01.2018, 02:24
Цитата Сообщение от ProRight Посмотреть сообщение
что такое bs.
Это bindingSource.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.01.2018, 02:24
Помогаю со студенческими работами здесь

Как можно оптимизировать запрос выборки по двум датам из БД Sqlite?
Составил запрос по выборки максимальных значений из двух полей с датами, используя несколько связанных таблиц: SELECT...

Как отобразить данные из SQLite в DataGridView?
Как отобразить данные с БД SQLite в DataGridView, подскажите, пожалуйста... Добавлено через 2 часа 54 минуты Спасибо за неответ)...

Как оптимизировать код?
Условие задачи(для понимания): Несколько учеников 10А класса физико-математической школы поспорили, кто из них самый популярный в...

Как оптимизировать код?
мне нужно чтобы значения угла перебирались от начального до конечного в зависимости от времени, выдает ошибку, как сделать правильно...

Как оптимизировать код?
Как оптимизировать код, чтобы работала программа быстрее #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;iomanip&gt; using...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru