Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/15: Рейтинг темы: голосов - 15, средняя оценка - 4.87
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510

MySQL Update запрос и открытый DataReader

25.02.2016, 07:49. Показов 3035. Ответов 8

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток!
Необходимо чтобы при загрузке консольного приложения, выполнялся всего один запрос. Вот он:
C#
1
2
MySqlCommand upd = new MySqlCommand("UPDATE table_name SET result = '1' WHERE phone= '"+mobile+"'", myCon);
upd.ExecuteNonQuery();
Т.е. есть столбец result, в котором по умолчанию все значения равны 0, а когда я запускаю приложение все записи должны обновляться на 1. Сам цикл который пробегает по всем записям, и выявляет у кого 0, я сделал, меня интересует только запрос. Помогите пожалуйста, что я не так делаю? При выполнении такого запроса, приложение пишет ошибку "There is already an open DataReader associated with this Connection which must be closed first.".
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.02.2016, 07:49
Ответы с готовыми решениями:

System.InvalidOperationException: Существует назначенный этой команде Command открытый DataReader
Доброго времени. C# начал изучать недавно. До работ с БД и изучению технологии ADO.net я не дошел, но обстоятельства сложились так, что мне...

Запрос MySQL без DataReader
Можно ли получить ответ от запроса без DataReader? Если да ,то как это составить("Select now()"): Dim cmd4 As New...

Ошибка: Существует назначенный этой команде Command открытый DataReader
Доброго времени суток! Разрабатываю сайт на ASP.NET MVC и мне потребовалось вывести список товаров. У каждого товара есть свойства,...

8
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18292 / 14216 / 5368
Регистрация: 17.03.2014
Сообщений: 28,894
Записей в блоге: 1
25.02.2016, 10:35
ember74, в ошибке всё сказано. Нужно закрыть ранее открытый DataReader.
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
25.02.2016, 10:49  [ТС]
я не могу его закрыть, т.к. у меня такая ситуация примерно
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
using (MySqlCommand cmd = new MySqlCommand("SELECT name FROM table_name", myCon))
{
    using (MySqlDataReader reader = cmd.ExecuteReader())
   {
        while (reader.Read())
        {
                //вывод данных (не буду вдаваться в подробности)
                //while пробегает по всем записям, и если видео запись у которой в поле result стоит 0 , нужно выполнить запрос, а он не выполняется
                MySqlCommand upd = new MySqlCommand("UPDATE table_name SET result = '1' WHERE phone = '"+mobile+"'", myCon);
                upd.ExecuteNonQuery();
        }
   }
}
Объясните пожалуйста..
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18292 / 14216 / 5368
Регистрация: 17.03.2014
Сообщений: 28,894
Записей в блоге: 1
25.02.2016, 11:09
ember74, почему бы не выполнить один UPDATE запрос?
SQL
1
UPDATE TABLE_NAME SET RESULT = '1' WHERE phone = '...'  AND RESULT = 0
Если это по какой-то причине невозможно, то открой второе соединение для update запросов.
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
25.02.2016, 11:32  [ТС]
Я сильно извиняюсь, но не могли бы вы показать на примере по поводу второго соединения?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18292 / 14216 / 5368
Регистрация: 17.03.2014
Сообщений: 28,894
Записей в блоге: 1
25.02.2016, 11:47
Лучший ответ Сообщение было отмечено ember74 как решение

Решение

ember74, например, так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
using (MySqlCommand cmd = new MySqlCommand("SELECT name FROM table_name", myCon))
{
    using (MySqlDataReader reader = cmd.ExecuteReader())
    {
        while (reader.Read())
        {
            // вывод данных ...
            using (MySqlConnection myCon2 = new MySqlConnection("..."))
            {
                MySqlCommand upd = new MySqlCommand("UPDATE table_name SET result = '1' WHERE phone = '"+mobile+"'", myCon2);
                myCon2.Open();
                upd.ExecuteNonQuery();
            }
        }
    }
}
0
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
25.02.2016, 11:55  [ТС]
Спасибо большое! Ошибки нет, но данные с 0 на 1 почему то не изменились..Может ли быть ошибка в запросе?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18292 / 14216 / 5368
Регистрация: 17.03.2014
Сообщений: 28,894
Записей в блоге: 1
25.02.2016, 11:58
ember74, если бы в запросе была ошибка, то ты бы получил исключение. Проверяй логику своего кода.
1
 Аватар для ember74
9 / 8 / 2
Регистрация: 07.10.2015
Сообщений: 510
25.02.2016, 12:04  [ТС]
Дело в том, что неделю назад я этот же самый запрос проверял на php, все работало
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.02.2016, 12:04
Помогаю со студенческими работами здесь

Существует назначенный этой команде Command открытый DataReader, который требуется предварительно закрыть
Что за ошибка: Существует назначенный этой команде Command открытый DataReader, который требуется предварительно закрыть. Исключение типа...

Существует назначенный этой команде Command открытый DataReader, который требуется предварительно закрыть
Добрый день. Выполняю такой код: /// <summary> /// Разблокировать источник котировок /// </summary>...

Существует назначенный этой команде Command открытый DataReader, который требуется предварительно закрыть
Вот такая ошибка выскакивает при выполнении кода. Может кто сталкивался. //--------------------- SqlConnection con_sel_fil =...

Запрос UPDATE в mysql рнр не работает
нужно сделать редактирование записи в таблице при помощи UPDATE делал вроде как по статье да ничего не работает, выручайте люди ...

Ошибка PHP + MySQL. Не работает запрос UPDATE
Здраствуйте. При написании страници для редакторования собержимого базы SQL столкнулся с проблемой. По началу код запроса на обновление...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью 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. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru