Форум программистов, компьютерный форум, киберфорум
Наши страницы
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
MrMens2
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
1

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

12.01.2015, 14:59. Просмотров 550. Ответов 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
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.01.2015, 14:59
Ответы с готовыми решениями:

Как исправить исключение при работе с таблицей (Incorrect syntax near...)?
DateTime data = dateTimePicker1.Value; SqlCommand cmd = new...

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

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

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

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

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

server=localhost - оно такое вообще ест? попробуй server=127.0.0.1
0
OwenGlendower
Супер-модератор
Эксперт .NET
9690 / 8433 / 3613
Регистрация: 17.03.2014
Сообщений: 16,892
Записей в блоге: 1
12.01.2015, 16:08 3
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
MrMens2
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
12.01.2015, 17:50  [ТС] 4
OwenGlendower, переделал, посмотрим что будет (ошибка возникает после 5+ часов работы)

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

Добавлено через 4 минуты
Цитата Сообщение от igor_fl Посмотреть сообщение
Почитай про фреймворк Hibernate
Hibernate это хорошая реализация ORM. Только это Java библиотека, а здесь форум по C# . Думаю ты хотел посоветовать NHibernate все-таки.
0
MrMens2
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
12.01.2015, 18:12  [ТС] 7
Обновил до 6.9.5 сейчас, но я думаю вряд ли поможет, ну посмотрим что будет
0
MrMens2
0 / 0 / 0
Регистрация: 19.08.2014
Сообщений: 77
12.01.2015, 19:38  [ТС] 8
Ошибка не пропала после обновления MySql/Connector
0
Миниатюры
Исключение StackOverflowException при работе с MySQL  
OwenGlendower
Супер-модератор
Эксперт .NET
9690 / 8433 / 3613
Регистрация: 17.03.2014
Сообщений: 16,892
Записей в блоге: 1
12.01.2015, 22:37 9
MrMens2, покажи трассировку стека.
0
igor_fl
63 / 63 / 28
Регистрация: 18.03.2014
Сообщений: 794
Завершенные тесты: 2
13.01.2015, 01:00 10
OwenGlendower, виноват) да именно его)
0
OwenGlendower
Супер-модератор
Эксперт .NET
9690 / 8433 / 3613
Регистрация: 17.03.2014
Сообщений: 16,892
Записей в блоге: 1
24.01.2015, 12:32 11
MrMens2, удалось решить проблему?
0
24.01.2015, 12:32
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.01.2015, 12:32

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

Учебники и книги по работе с бд MySQL, Access, Oracle в C#
Приветствую. Так и не нашел нормальных книг и тем раскрывающих данный вопрос....

Одинарная кавычка в тексте, создает препятствия работе с MySQL
Здравствуйте! Проблема в следующем Есть текст экспортируемый из excell,...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru