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

Исключение StackOverflowException при работе с MySQL

12.01.2015, 14:59. Показов 1556. Ответов 10
Метки нет (Все метки)

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

вот код:

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
        private string getDate()
        {
            string connStr = "server=localhost;user=root;database=db;port=3306;password=root;";
            MySqlConnection conn = new MySqlConnection(connStr);
            try
            {
                conn.Open();
                MySqlCommand command = new MySqlCommand();
                string SQL = "SELECT * FROM `accs` WHERE email = 'true' limit 1";
                command.CommandText = SQL;
                command.Connection = conn;
                command.ExecuteScalar();
                MySqlDataReader reader = command.ExecuteReader();
                while (reader.Read())
                {
                    String login = reader.GetString(0);
                    String pass = reader.GetString(1);
                    conn.Close();
                    return login + ";" + pass;
                }
            }
            catch (Exception ex)
            {
                addToLog(ex.ToString());
            }
            conn.Close();
            return "0";
        }
Ошибка на строке "conn.Open();"
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.01.2015, 14:59
Ответы с готовыми решениями:

Как исправить исключение при работе с таблицей (Incorrect syntax near...)?
DateTime data = dateTimePicker1.Value; SqlCommand cmd = new SqlCommand("insert into GreenWich (Дата,Наира,Румия,Сакина,Анвер)values (+...

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

Использование транзакции при работе с MySQL
Здравствуйте! Есть подключение к БД SQL в которой всего две таблицы 1 -TEST_TRANS -(имеет одно поле "snils") 2-...

10
 Аватар для ITL
284 / 255 / 73
Регистрация: 17.07.2012
Сообщений: 618
12.01.2015, 16:04
Ты конечно прости. Но код ужасен. Точно выпадает ошибка на conn.Open(); ?
Почему у тебя стоит while и внутри...ты закрываешь соединение.
Почему ты не закрываешь соединение в catch(finally) блоке?

server=localhost - оно такое вообще ест? попробуй server=127.0.0.1
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18244 / 14158 / 5366
Регистрация: 17.03.2014
Сообщений: 28,847
Записей в блоге: 1
12.01.2015, 16:08
MrMens2, возможно это ошибка в MySql Connector/Net. Попробуй обновить его до последней версии. Но возможно проблема возникает из-за плохого освобождения ресурсов. Я бы переделал так:
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
private string getDate()
{
    const string connStr = "server=localhost;user=root;database=db;port=3306;password=root;";
    try
    {
        using (MySqlConnection conn = new MySqlConnection(connStr))
        {
            MySqlCommand command = new MySqlCommand();
            command.CommandText = "SELECT * FROM `accs` WHERE email = 'true' limit 1";;
            command.Connection = conn;
            conn.Open();
            using (MySqlDataReader reader = command.ExecuteReader())
            {
                if (reader.Read())
                {
                    string login = reader.GetString(0);
                    string pass = reader.GetString(1);
                    return login + ";" + pass;
                }
            }
        }
    }
    catch (Exception ex)
    {
        addToLog(ex.ToString());
    }
    return "0";
}
К коду есть еще вопросы, но их лучше обсудить попозже пока не решена основная проблема.
0
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
12.01.2015, 17:50  [ТС]
OwenGlendower, переделал, посмотрим что будет (ошибка возникает после 5+ часов работы)

Добавлено через 1 час 25 минут
Все равно ошибка на "conn.Open();"
0
 Аватар для igor_fl
63 / 63 / 28
Регистрация: 18.03.2014
Сообщений: 794
12.01.2015, 17:53
Почитай про фреймворк Hibernate. Очень удобная вещь для работы с базами
Здесь можно
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18244 / 14158 / 5366
Регистрация: 17.03.2014
Сообщений: 28,847
Записей в блоге: 1
12.01.2015, 18:01
Цитата Сообщение от MrMens2 Посмотреть сообщение
Все равно ошибка на "conn.Open()
Обновлять MySql/Connector пробовал?

Добавлено через 4 минуты
Цитата Сообщение от igor_fl Посмотреть сообщение
Почитай про фреймворк Hibernate
Hibernate это хорошая реализация ORM. Только это Java библиотека, а здесь форум по C# . Думаю ты хотел посоветовать NHibernate все-таки.
0
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
12.01.2015, 18:12  [ТС]
Обновил до 6.9.5 сейчас, но я думаю вряд ли поможет, ну посмотрим что будет
0
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
12.01.2015, 19:38  [ТС]
Ошибка не пропала после обновления MySql/Connector
Миниатюры
Исключение StackOverflowException при работе с MySQL  
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18244 / 14158 / 5366
Регистрация: 17.03.2014
Сообщений: 28,847
Записей в блоге: 1
12.01.2015, 22:37
MrMens2, покажи трассировку стека.
0
 Аватар для igor_fl
63 / 63 / 28
Регистрация: 18.03.2014
Сообщений: 794
13.01.2015, 01:00
OwenGlendower, виноват) да именно его)
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18244 / 14158 / 5366
Регистрация: 17.03.2014
Сообщений: 28,847
Записей в блоге: 1
24.01.2015, 12:32
MrMens2, удалось решить проблему?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.01.2015, 12:32
Помогаю со студенческими работами здесь

Обработка ошибок при работе с БД MySQL
Здравствуйте. Необходимо обработать такие исключения как нет подключения к серверу/неверный адрес, не найдена БД, неверный пароль или...

Есть ли минусы в замене Access на MySQL при использовании ADO.NET в работе с ними
Подскажите, пожалуйста - есть ИС, состоящая из приложения Windows и комплекта БД Access, взаимодействие с которыми осуществляется через...

Более 1000 запросов к БД MySQL и ошибка "System.StackOverflowException"
программа выполняет по очереди Mysql запросы. При регистрации просто закидывает запрос в очередь (List<Turn>) и по очереди выполняет....

Ошибка System.StackOverflowException при использовании StreamReader
У меня есть метод, которой получает два числа из файла: protected void GetNumbers() { using (StreamReader...

System.StackOverflowException при работе с любыми файлами
Здравствуйте! При работе с файлами в каких-то методах появляется исключение System.StackOverflowException. Попробовал: ...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru