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

Работа с базой mySQL. Проблемы с коннектом

19.02.2013, 21:14. Показов 3049. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Обращаюсь к Вам, потому как не могу в гугле найти решение проблемы. Создал приложение на языке C#. Оно работает с базой данных mySql через mySqlConnector.
Отправка запроса происходит таким образом:
1. открывается соединение;
2. выполняется запрос;
3. закрывается соединение.

Проблема в том, что постоянное открытие и закрытие соединения, плачевно сказывается на сервере и он попросту рвет соединение. Это в основном происходит если например подряд выполнить три селекта. Постоянно открытым соединение держать не можна, транзакции не помогают. Подскажите что лучше почитать что бы разобраться и сделать как нужно. Если нужен код - могу выложить. Заранее большое спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.02.2013, 21:14
Ответы с готовыми решениями:

Работа с MySQL базой данных
Сделал я кнопку "Зарегистрироваться", только она не работает. Вот код: JButton bt1 = new JButton("Зарегистрироваться"); ...

Работа с MySQL базой данных
Когда я ввожу в текстовое поле значение из базы данных и нажимаю кнопку - ничего не происходит public class prog { public static...

Работа с базой данных MySQL средствами PHP
Здравствуйте! Помогите,пожаалуйста((( с запросом по Mysql,все-таки не получается вывести максимальное количество часов. (( ...

12
 Аватар для sigmov
585 / 372 / 63
Регистрация: 22.07.2009
Сообщений: 875
Записей в блоге: 4
20.02.2013, 01:38
А почему бы тогда не выполнять эти 3 селекта в рамках одного соединения?
0
0 / 0 / 0
Регистрация: 19.02.2013
Сообщений: 6
20.02.2013, 02:00  [ТС]
Запросы могут идти с разных классов. Или же последовательно, например если перелистывать календарь, и для каждого дня будут выбираться определенные данные. В таких случаях рвется соединение, и приходится ждать пока оно восстановится.
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
20.02.2013, 08:22
Цитата Сообщение от _Bombaster_ Посмотреть сообщение
Если нужен код - могу выложить.
Хотелось бы взглянуть.
Цитата Сообщение от _Bombaster_ Посмотреть сообщение
Проблема в том, что постоянное открытие и закрытие соединения, плачевно сказывается на сервере и он попросту рвет соединение.
Надеюсь, что у вас не 1000 итераций цикла в каждой из которых открывается и закрывается соединение. Это верный путь к падению MySql.
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
20.02.2013, 09:52
Явно глючный сервер
Цитата Сообщение от _Bombaster_ Посмотреть сообщение
постоянное открытие и закрытие соединения, плачевно сказывается на сервере и он попросту рвет соединение
Такого не должно быть. Сервер не может (не должен) падать из-за 10 одновременных подключений.
Ну или как вариант глючный код. Посмотри документацию на свой сервак, возможно проблема в том, что ты не закрываешь ранее открытые соединения и превышаешь лимит одновременных подключений.
0
0 / 0 / 0
Регистрация: 19.02.2013
Сообщений: 6
20.02.2013, 12:45  [ТС]
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
private MySqlConnection _connection;
        private string _server;
        private string _database;
        private string _uid;
        private string _password;
 
        private bool OpenConnection()
        {
                _server = "сервер";
                _database = "база";
                _uid = "логин";
                _password = "пароль";
 
            string connectionString = "SERVER=" + _server + ";" + "DATABASE=" + _database + ";" + "UID=" + _uid + ";" + "PASSWORD=" + _password + ";" + "charset=utf8";
 
            _connection = new MySqlConnection(connectionString);
 
            _connection.Close();
            try
            {
                _connection.Open();
                return true;
            }
            catch(Exception ex)
            {
                if (ex is MySqlException)
                {
                    var msex = (MySqlException)ex;
                    switch (msex.Number)
                    {
                        case 0:
                            {
                                var wwm = new WorkWithMessages();
                                wwm.ShowM(@"Не возможно подключение к серверу. Обратитесь к администратору.");
                                break;
                            }
 
                        case 1045:
                            {
                                var wwm = new WorkWithMessages();
                                wwm.ShowM(@"Неправильные username/password, пожалуйста попробуйте еще раз.");
                                break;
                            }
                    }
                    return false;
                }
                return false;
            }
        }
 
        private bool CloseConnection()
        {
            bool status;
            try
            {
                _connection.Close();
                status = true;
            }
            catch (MySqlException ex)
            {
                var wwm = new WorkWithMessages();
                wwm.ShowM(ex.Message);
                status = false;
            }
            return status;
        }
 
        public void Insert(string query)
        {
            if (OpenConnection())
            {
                var cmd = new MySqlCommand(query, _connection);
                cmd.ExecuteNonQuery(); 
                CloseConnection();
            }
        }
 
        public MySqlDataReader Select(string query)
        {
            OpenConnection(); 
            var cmd = new MySqlCommand(query, _connection);
            MySqlDataReader myDataReader = cmd.ExecuteReader();
            return myDataReader;
            CloseConnection(); 
        }
 
        public void Update(string query)
        {
            if (OpenConnection())
            {
                var cmd = new MySqlCommand();
                cmd.CommandText = query;
                cmd.Connection = _connection;
 
                cmd.ExecuteNonQuery();
 
                CloseConnection();
            }
        }
        public void Delete(string query)
        {
            if (OpenConnection())
            {
                var cmd = new MySqlCommand(query, _connection);
                cmd.ExecuteNonQuery();
                CloseConnection();
            }
        }
Это код всего класса, что отвечает за работу с сервером.

У меня в программе могут быть не более 2 одновременных соединений. Остальные идут поочередно. Я еще забыл сказать, что если открыть другой экземпляр этой программы (например на другом компьютере), то еще быстрее рвется соединение (одновременно на двух компьютерах).

Добавлено через 5 минут
Цитата Сообщение от nio Посмотреть сообщение
Посмотри документацию на свой сервак, возможно проблема в том, что ты не закрываешь ранее открытые соединения и превышаешь лимит одновременных подключений.
Гляньте, плиз, код. Возможно где-то допустил ошибку не закрыв соединение, но вроде все правильно.
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
20.02.2013, 12:46

Не по теме:

Теги кода хорошая вещь


В методах Insert Select если сервер вернул ошибку запросов (ExecuteNonQuery) соединение не закрывается и вылетает исключение.
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
20.02.2013, 13:01
Ошибки:
стр 18: зачем закрытие соединения сразу после его инициализации?
стр 84: вызов метода закрытия соединения недостижим, до него происходит return, т.е. после использования ридера соединение не закрывается.

Во всех методах, если произойдет исключение, соединение не будет закрыто.

Есть еще мысль о том, что сервер имеет механизм автоматического закрытия соединения по таймауту (т.е. нельзя держать открытое соединение час), нужно читать доку по серверу.
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
20.02.2013, 13:05
Должно быть что-то типа того
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public void Insert(string query)
        {
            if (OpenConnection())
            {
                var cmd = new MySqlCommand(query, _connection);
                try
                {
                   cmd.ExecuteNonQuery(); 
                }
                 catch (Exception ex)
                 {
                     // обработка ошибки
                  }
                 finally
                 {
                       CloseConnection();
                  }
                   
            }
        }
1
0 / 0 / 0
Регистрация: 19.02.2013
Сообщений: 6
20.02.2013, 13:51  [ТС]
Цитата Сообщение от gitarillo Посмотреть сообщение
Должно быть что-то типа того
Спасибо большое за пример, исправил.

Добавлено через 1 минуту
Цитата Сообщение от nio Посмотреть сообщение
стр 84: вызов метода закрытия соединения недостижим, до него происходит return, т.е. после использования ридера соединение не закрывается.
Если вызывать метод закрытия соединения до return, то данные не возвращаются. Не знаю в чем проблема.

Добавлено через 39 секунд
Цитата Сообщение от nio Посмотреть сообщение
Во всех методах, если произойдет исключение, соединение не будет закрыто.
Исправил. Спасибо.

Добавлено через 22 минуты
Нашел, в чем была проблема. Я не закрывал ридер при каждом селекте.
Помогите как это решить:
public MySqlDataReader Select(string query)
{
OpenConnection();
var cmd = new MySqlCommand(query, _connection);
MySqlDataReader myDataReader = cmd.ExecuteReader();
return myDataReader;
CloseConnection();
}
как правильно написать что бы закрывалось соединение после выполнения метода. Если вызвать закрытие до return, то никакие данные не возвращаются.
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
20.02.2013, 14:16
Цитата Сообщение от _Bombaster_ Посмотреть сообщение
Если вызвать закрытие до return, то никакие данные не возвращаются.
Потому что чтобы пользоваться ридером, соединение должно быть открыто. советую пользоваться датасетом.
1
0 / 0 / 0
Регистрация: 28.01.2013
Сообщений: 5
20.02.2013, 20:02
Еще у telerik есть open access orm и там поддерживается мускуль.
0
0 / 0 / 0
Регистрация: 19.02.2013
Сообщений: 6
20.02.2013, 21:25  [ТС]
Всем спасибо за помощь. Проблема решена.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.02.2013, 21:25
Помогаю со студенческими работами здесь

Работа с базой данных MySQL средствами PHP
Здравствуйте, помогите пожалуйста, написать запрос, выбирающий все данные из таблицы STUDENT, расположив столбцы таблицы в следующем...

Работа с базой данных MySQL средствами PHP
Здравствуйте,Помогите пожалуйста с запросом по SQL.. не получается вывести список предметов. Получить список предметов, на изучение...

Работа с базой MySQL/Oracle из кода программы на С/С++
Как работать с базой MySQL/Oracle из кода программы на С/С++, без использования MFC, API и с полной совместимостью с Windows/Linux?

Работа с базой MySQL через собственный класс
Здравствуйте! Пытаюсб освоить ООП на PHP. Так сказать, для тренировки решил написать класс, который будет работать с БД. Все просто: от...

C++Builder 2009 + MySQL 5.1 через DBX - проблеммы с коннектом
Создаю TSQLConnection, конекчу к локальной MySQL - отлично. Создаю TSQLDataSet, ввожу тестовый запрос, заполняю, в общем, все параметры,...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru