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

BackgroundWorker и запрос к mssql

26.04.2016, 12:42. Показов 1991. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, есть код

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
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
        {
            RetriveTableData Obj = (RetriveTableData)e.Argument;
            string SqlcmdString = "SELECT dbo.ObjectNumberToString(ObjectNumber) as StringObjectNumber, Name, Address, RecordDeleted FROM Objects_ss ORDER BY ObjectNumber";
            SqlDataReader reader;
            int i = 1;
            try
            {
                using (SqlConnection conn = new SqlConnection(ConnString))
                {
                    Sqlcmd = new SqlCommand(SqlcmdString, conn);
                    conn.Open();
                    reader = Sqlcmd.ExecuteReader();
 
                        while (reader.Read())
                        {
                            Obj.EmpIdN = i.ToString();
                            Obj.EmpId = reader["StringObjectNumber"].ToString();
                            Obj.EmpName = reader["Name"].ToString();
                            Obj.EmpAddress = reader["Address"].ToString();
                            backgroundWorker1.ReportProgress(i, Obj);
                            Thread.Sleep(10);
 
                            if (backgroundWorker1.CancellationPending)
                            {
                                e.Cancel = true;
                                backgroundWorker1.ReportProgress(0);
                                return;
                            }
                            i++;
                        }
                        conn.Close();
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
Выводит в dataGridView такие данные:

1 1 Окна "Окна" Калинина, 3
4 4 +267 Горького, 2
4 4 +267 Горького, 2
5 5 Пиво 78 Добровольческой Бригады, 34
5 5 Пиво 78 Добровольческой Бригады, 34
11 11 Пост охраны "455" Красной Звезды, 15 А

Проблема следующая, некоторые строки либо не выводятся либо задвоенные выводятся, должно быть вот так:

1 1 Окна "Окна" Калинина, 3
2 2 Чистые луга Маерчака, 42
3 3 Цветы "Цветы" справа от сладкой жизни К.Маркса, 29 Е
4 4 +267 Горького, 2
5 5 Пиво 78 Добровольческой Бригады, 34

Пробовал lock:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
        private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
        {
            if (!backgroundWorker1.CancellationPending)
            {
                lock (sync)
                {
                    RetriveTableData Obj = (RetriveTableData)e.UserState;
                    dataGridView1.Rows.Add(Obj.EmpIdN.ToString(), Obj.EmpId.ToString(), Obj.EmpName.ToString(), Obj.EmpAddress.ToString());
                    progressBar1.Value = e.ProgressPercentage;
                    progressBarlabel1.Text = "Загруженно данных.. " + e.ProgressPercentage.ToString() + " из " + TotalRecords;
                }
            }
        }
Не помогает.

Если sleep выставить больше 200, выводит правильно но очень долго, 3000 строк нужно показать.
Подскажите пожалуйста что нужно использовать и где?

Добавлено через 18 часов 36 минут
Что совсем ни кто не знает?
И не может советом помочь?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.04.2016, 12:42
Ответы с готовыми решениями:

Как в Delphi сделать запрос на запрос, база mssql, BDE
Добрый день! Кто-нибудь может подсказать, как можно Tquery и использовать как таблицу, при написании другого запроса? Заранее спасибо!

Запрос к MSSQL
Здравствуйте! Подскажите пожалуйста, как в VBNET организовать запрос из MSSQL. Раньше я работал в Access и там для любого элемента...

GET-запрос к MSSQL
доброе утро ! не могу понять, как заставить работать запрос. есть файл, который посылает гет-запрос к мсскл базе. если выполнить его в...

12
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
26.04.2016, 16:49
Цитата Сообщение от Frost_Rus Посмотреть сообщение
Что совсем ни кто не знает?
И не может советом помочь?
Не совсем понятно, что вам требуется.
Для начала, зачем вы использовали работу с БД в другом потоке? Записей так много, что интерфейс притормаживает?
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
26.04.2016, 17:13
Цитата Сообщение от Frost_Rus Посмотреть сообщение
3000 строк нужно показать.
в datagrid 3k строк? . Зачем?
0
0 / 0 / 0
Регистрация: 22.04.2016
Сообщений: 6
26.04.2016, 17:50  [ТС]
Цитата Сообщение от insite2012 Посмотреть сообщение
Не совсем понятно, что вам требуется.
Для начала, зачем вы использовали работу с БД в другом потоке? Записей так много, что интерфейс притормаживает?
Если просто загружать без потока то интерфейс зависает, это не приятно.
Хочется чтобы был доступ к другим функциям формы.

Добавлено через 46 секунд
Цитата Сообщение от pincet Посмотреть сообщение
в datagrid 3k строк? . Зачем?
Что бы получить полное количество объектов. базы данных.
Как по другому не знаю, так как только начинаю изучать си шарп.
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
26.04.2016, 17:56
Цитата Сообщение от Frost_Rus Посмотреть сообщение
Что бы получить полное количество объектов. базы данных.
Frost_Rus, вы в состоянии одномементно охватить взглядом 3к строк? Вероятно, нет. Так зачем столько загружаете. Грузите их частями.
0
0 / 0 / 0
Регистрация: 22.04.2016
Сообщений: 6
26.04.2016, 18:11  [ТС]
Добавлено через 46 секунд
Цитата Сообщение от pincet Посмотреть сообщение
в datagrid 3k строк? . Зачем?
Что бы получить полное количество объектов. базы данных.
Как по другому не знаю, так как только начинаю изучать си шарп.
На самом деле строк может быть и больше.
Но загружать их надо все, сразу.

Добавлено через 1 минуту
Цитата Сообщение от insite2012 Посмотреть сообщение
Frost_Rus, вы в состоянии одномементно охватить взглядом 3к строк? Вероятно, нет. Так зачем столько загружаете. Грузите их частями.
Т.е. по мере прокрутки (по строчно как в PHP), или как то по другому?

Можете код подсказать реализации такого варианта?

Добавлено через 12 минут
Цитата Сообщение от insite2012 Посмотреть сообщение
Frost_Rus, вы в состоянии одномементно охватить взглядом 3к строк? Вероятно, нет. Так зачем столько загружаете. Грузите их частями.
Опять же скорее всего будут задержки загрузки данных, при пролистывании страницы.
ЗЫ я конечно не уверен (предположение только). Т.к. не нашел еще примера такой загрузки.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
26.04.2016, 20:06
Попробуйте убрать
Цитата Сообщение от Frost_Rus Посмотреть сообщение
ORDER BY ObjectNumber
. Сортировка по неиндексированному столбцу может сильно замедлить запрос.
0
0 / 0 / 0
Регистрация: 22.04.2016
Сообщений: 6
27.04.2016, 03:55  [ТС]
Цитата Сообщение от Igr_ok Посмотреть сообщение
Попробуйте убрать . Сортировка по неиндексированному столбцу может сильно замедлить запрос.
Запрос к базе данных быстро работает. У меня медленно данные в gridview выводит из за того что sleep больше 200 мс. Если ставить sleep 50 то данные в gridview выводятся быстро но, либо не все либо задвоенные как в первом посте.
Я пробовал использовать lock но это не помогло.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
27.04.2016, 14:42
Цитата Сообщение от Frost_Rus Посмотреть сообщение
Если ставить sleep 50 то данные в gridview выводятся быстро
На 3к записей это 150 секунд.
Цитата Сообщение от Frost_Rus Посмотреть сообщение
Если просто загружать без потока то интерфейс зависает, это не приятно.
Пытаясь решить маленькую проблему, вы создали большую.
0
0 / 0 / 0
Регистрация: 22.04.2016
Сообщений: 6
27.04.2016, 16:32  [ТС]
Совершенно верно.
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
27.04.2016, 20:24
Цитата Сообщение от Frost_Rus Посмотреть сообщение
Совершенно верно.
Frost_Rus, вы определите, сколько строк одномоментно нужно выводить. Потом обработайте событие Scroll у DataGridView, и в нем обновляйте отображение следующей (или предыдущей) порцией данных.
0
0 / 0 / 0
Регистрация: 22.04.2016
Сообщений: 6
27.04.2016, 20:29  [ТС]
А обновлять порции лучше в потоке или нет?
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
27.04.2016, 20:36
Лучший ответ Сообщение было отмечено pincet как решение

Решение

Цитата Сообщение от Frost_Rus Посмотреть сообщение
обновлять порции лучше в потоке или нет?
Можно и в потоке.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
27.04.2016, 20:36
Помогаю со студенческими работами здесь

запрос mssql
как в sql servere написать запрос поиска таблицы, зная название столбца этой таблицы. При этом баз много, то есть я не могу зайти именно в...

Создать запрос к бд mssql
Всем привет, пытаюсь подключиться к бд icrosoftsql. Делаю это через dbexpress, там есть sql connection. В параметрах выставляю:...

MSSQL. Параметризированный запрос
Привет ! Есть следующая конструкция: select * from blablabla where blabalba IN ('x1','x2'); нужно передавать список который в...

Запрос - фильтрация mssql
Здравствуйте, не могу разобраться, как правильно прописать фильтрацию по нескольким значениям переменной ? ADOQuery1.SQL.Text :='SELECT...

Оптимизировать запрос mssql
Есть запрос: SELECT max(dt) as dt, max() - min() as , -- разница м/д значениями в 19:59:00 и 19:00:00 max() - min() as , max()...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru