Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
 Аватар для siriusED
32 / 31 / 13
Регистрация: 20.05.2010
Сообщений: 705

Доступ к базе из множества потоков

12.11.2013, 10:35. Показов 1734. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Во общем у меня проблема, есть несколько потоков, и мне нужно что б каждый поток мог выбирать из базы общое количество полей и добавлять новые поля.

Но что-то у меня не получается ничерта... Когда один поток всё нормально работает, а когда два то пишет:
"There is already an open DataReader associated with this Connection which must be closed first."

C#
1
2
3
4
5
6
7
8
                    lock (LOCKER_check_database2)
                    {
                        using (MySqlCommand command = new MySqlCommand("INSERT INTO `Requests` (`Request`) VALUES" +
                            String.Format("('{0};{1};{2};')", value1, value2, value3), dataBaseConnection))
                        {
                            command.ExecuteNonQuery(); // Вот тут исключение.
                        }
                    }

Подскажите в чом косяк?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.11.2013, 10:35
Ответы с готовыми решениями:

Доступ к базе данных на базе хранимых процедур MySQL из php
Добрый день возник вопрос по доступ к базе данных на базе хранимых процедур MySQL из php Из файла php подключаюсь к бд вот так ...

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

доступ к базе №2 из агента в базе №1
есть база, в ней агент. из агента идет обращение к другой базе на сервере выборка данных и вставка в базу. если запускать агант по действию...

6
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
12.11.2013, 11:56
Что бы не парится с блокировками делайте класс не статичным, а экземплярным. Используйте конструкции вида

C#
1
2
3
4
5
6
7
8
9
10
11
                using (var conn = new SqlConnection(ConnectionString))
                {
                    conn.Open();
                    using (var comm = new SqlCommand("INSERT INTO Table ...", conn))
                    {                        
                        using (SqlDataReader reader = comm.ExecuteReader())
                        {
                        
                        }
                    }
                }
1
 Аватар для ksk
624 / 495 / 43
Регистрация: 05.07.2010
Сообщений: 1,589
12.11.2013, 12:12
Главное в этом деле не открывать одновременно несколько ридеров из одного соединения. Остальное - вопрос аккуратности только.
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
12.11.2013, 13:20
Цитата Сообщение от siriusED Посмотреть сообщение
Но что-то у меня не получается ничерта... Когда один поток всё нормально работает, а когда два то пишет
Скорее всего второй поток, не закрыл reader, или читает из Reader вне lock-а.
0
 Аватар для siriusED
32 / 31 / 13
Регистрация: 20.05.2010
Сообщений: 705
12.11.2013, 20:26  [ТС]
Такс, ну а разве на одно соиденение может быть только один ридер или что? А как мне тогда реализовать три секции в которых происходит считывание информации из базы? Неужели нужно делать три разных соиденения?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
12.11.2013, 20:36
Цитата Сообщение от siriusED Посмотреть сообщение
Неужели нужно делать три разных соиденения?
Да, я же написал пример кода.
1
 Аватар для siriusED
32 / 31 / 13
Регистрация: 20.05.2010
Сообщений: 705
13.11.2013, 04:13  [ТС]
Ну вроде работает, спасибо. Надеюсь это решение не костыль.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.11.2013, 04:13
Помогаю со студенческими работами здесь

QSqlDatabase к одной базе из разных потоков
У меня многопоточное приложение. В одном потоке (главном) я соединяюсь с некоторой базой данных и с ней работаю (чтение) Есть еще один...

Доступ к БД с разных потоков
как реализовать доступ к одной базе данных с разных потоков? когда один сервер обрабатывает несколько клиентов то у меня выходит...

Доступ к данным из пула потоков
У меня в основном потоке формируется матрица такая: int matrix = new int; Потом создаю пул потоков: ThreadPool.SetMinThreads(4,...

Множественный доступ потоков к коллекциям
Здравствуйте. Подскажите в какую сторону копать. У меня есть 8 потоков. Каждый поток получается данные (структура в 10 полей) от...

Доступ к массиву из соседних потоков
Когда в потоках AvergeDistance и range_numbers , обращаются к массиву A, вылетает с ошибкой: Ссылка на объект не указывает на...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru