6 / 3 / 0
Регистрация: 04.05.2018
Сообщений: 407

Error while creating table 2055: Lost connection to MySQL server at 'localhost:3306', system error

28.10.2020, 17:53. Показов 5439. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Сейчас реализовываю БД для приложения. Ничего не предвещало беды ровно до тех пор пока я не получил ошибку в следующем коде:
code

Python
1
2
3
4
5
6
7
8
9
10
    # Создаем таблицы, если они не существуют
    def __create_tables(self):
        try:
            self.cursor = self.__get_cursor()
            self.cursor.execute(DataBaseQueries.CREATE_USER_DATA_TABLE)
            self.cursor.execute(DataBaseQueries.CREATE_MEETING_TABLE)
            self.cursor.close()
            logging.info("Tables created successfully")
        except mysql.connector.Error as error:
            logging.error("Error while creating table {}".format(error))
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# Где-то в другом классе описаны константы с запросами
    CREATE_USER_DATA_TABLE = ("CREATE TABLE IF NOT EXISTS " + TABLE_USER_DATA + " (" +
                              USER_ID + " TINYTEXT, " +
                              USER_NICKNAME + " TINYTEXT NOT NULL, " +
                              USER_PASSWORD + " TINYTEXT NOT NULL, " +
                              USER_AVATAR + " TINYTEXT, " +
                              "PRIMARY KEY (" + USER_ID + "(10)));")
 
    CREATE_MEETING_TABLE = ("CREATE TABLE IF NOT EXISTS ", TABLE_MEETING + " (" +
                            MEETING_ID + " TINYTEXT, " +
                            USER_ID + " TINYTEXT NOT NULL, " +
                            MEETING_NAME + " TINYTEXT NOT NULL, " +
                            MEETING_DATE + " DATETIME NOT NULL, " +
                            MEETING_ADDRESS + " TINYTEXT NOT NULL, " +
                            MEETING_DESCRIPTION + " TEXT, " +
                            MEETING_IMAGE + " TINYTEXT, + "
                            "PRIMARY KEY (" + MEETING_ID + "(10)));")

Ошибка выглядит вот так:
Error

Error while creating table 2055: Lost connection to MySQL server at 'localhost:3306', system error: Connection not available

Напрямую из MySQL Workbench запросы выполняются без нареканий, из python получаю следующую ошибку. Что я сделал не так? В чем возможно таиться проблема?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.10.2020, 17:53
Ответы с готовыми решениями:

ERROR 2013: Lost connection to MySQL server during query
Ошибка возникла при написании длинной таблицы. Сервер локальный - OpenServer. MySQL - Версия 5.7 Возможно это из-за какого-то таймера. ...

QSqlDatabase + OpenMP = Error: Lost connection to MySQL server during query
Добрый день! Возникает ошибка при использовании QSqlDatabase и OpenMP.

Как исправить Error Code: 2013. Lost connection to MySQL server during query
Здравствуйте. Есть запрос по импорту большого файла в базу данных формата LOAD DATA INFILE 'файл.csv' INTO TABLE pma.nsn3g ...

11
5021 / 1047 / 147
Регистрация: 29.01.2013
Сообщений: 6,149
29.10.2020, 08:37
я не вижу фрагмента кода с подключением к БД
0
6 / 3 / 0
Регистрация: 04.05.2018
Сообщений: 407
29.10.2020, 08:54  [ТС]
Alli_Lupin,
Цитата Сообщение от Alli_Lupin Посмотреть сообщение
я не вижу фрагмента кода с подключением к БД
Подключение к MySQL server

Python
1
2
3
4
5
6
7
8
9
10
11
    def __connect_to_mysql_server(self):
        try:
            self.connection = mysql.connector.connect(
                host = "localhost",
                user = "root",
                password = "*******",
                database = self.NAME_DATABASE
            )
            logging.info("MySQLServer: connected")
        except:
            logging.error("Error connecting to MySQLServer")
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7384 / 4806 / 1244
Регистрация: 30.03.2015
Сообщений: 13,633
Записей в блоге: 29
29.10.2020, 09:01
MetMark, а разве если мы что-то создаем в БД, а не просто просим данные не нужно выполнять cursor.commit() ?
я верно понимаю что вы создаете и закрываете курсор для каждого метода, вместо того чтобы использовать 1 на всех?
0
6 / 3 / 0
Регистрация: 04.05.2018
Сообщений: 407
29.10.2020, 09:03  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
вы создаете и закрываете курсор для каждого метода
Да, верно. Я для начала использовал 1 на всех, но потом не знаю почему решил его закрывать.

Вы считаете, что на время взаимодействия с MySQL server-ом лучше создать один курсор и только им пользоваться?
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7384 / 4806 / 1244
Регистрация: 30.03.2015
Сообщений: 13,633
Записей в блоге: 29
29.10.2020, 09:07
Цитата Сообщение от MetMark Посмотреть сообщение
Вы считаете, что на время взаимодействия с MySQL server-ом лучше создать один курсор и только им пользоваться?
ну мне кажется так проще, зачем чего то создавать и закрывать постоянно. Только обязательно сделать метод, который закроет в итоге и курсор и соединение после того как поработаем. Еще лучше сразу написать это или в деструкторе или в блоке трай файналли, чтобы закрывать соединение в любом случае, даже если ты поймал исключение. Менеджер контекста тоже подойдет
3
6 / 3 / 0
Регистрация: 04.05.2018
Сообщений: 407
29.10.2020, 10:43  [ТС]
Welemir1,
Цитата Сообщение от Welemir1 Посмотреть сообщение
выполнять cursor.commit()
Дописал, теперь мне выдает уже другую ошибку:
Error

'CMySQLCursor' object has no attribute 'commit'

Далее попробовал такую запись увидев пример вот тут:
Code

Python
1
2
3
4
5
6
7
8
9
10
    # Создаем таблицы, если они не существуют
    def __create_tables(self):
        try:
            self.cursor.execute(DataBaseQueries.CREATE_USER_DATA_TABLE)
            self.connection.commit()
            self.cursor.execute(DataBaseQueries.CREATE_MEETING_TABLE)
            self.connection.commit()
            logging.info("Tables created successfully")
        except mysql.connector.Error as error:
            logging.error("Error while creating table {}".format(error))

Курсор вот так получаю
Code

Python
1
2
3
4
5
6
7
    # Получаем обьект "cursor" с помощью которого мы будем выполнять запросы
    def __get_cursor(self):
        try:
            logging.info("Cursor received")
            return self.connection.cursor()
        except:
            logging.error("Cursor not received")
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7384 / 4806 / 1244
Регистрация: 30.03.2015
Сообщений: 13,633
Записей в блоге: 29
29.10.2020, 10:47
MetMark, я с бд давно не работал, мог и спутать, главное коммит делать после правок.
1
6 / 3 / 0
Регистрация: 04.05.2018
Сообщений: 407
29.10.2020, 10:52  [ТС]
Welemir1,
Цитата Сообщение от MetMark Посмотреть сообщение
Далее попробовал такую запись увидев пример вот тут
Проблема в том, что ошибку продолжает выдавать, только вот эту:
Error

Lost connection to MySQL server at 'localhost:3306', system error: Connection not available
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7384 / 4806 / 1244
Регистрация: 30.03.2015
Сообщений: 13,633
Записей в блоге: 29
29.10.2020, 10:57
Лучший ответ Сообщение было отмечено MetMark как решение

Решение

Цитата Сообщение от MetMark Посмотреть сообщение
что ошибку продолжает выдавать, только вот эту:
а не может получиться что ты уже кучу соединений насоздавал и не закрыл их? попробуй комп и БД перезагрузить. Если не получится, то надо уже гуглить, может что то специфическое для мускуля
0
6 / 3 / 0
Регистрация: 04.05.2018
Сообщений: 407
29.10.2020, 11:33  [ТС]
Welemir1,
Цитата Сообщение от Welemir1 Посмотреть сообщение
попробуй комп и БД перезагрузить
Перезагрузил ПК, заново запустил MySQL server, запустил код, та же ошибка. В любом случае спасибо за потраченное вами время

Welemir1, вероятно где-то накосячил я. Только что создал отдельный файлик и там прописал минимум кода для создания в своей БД новой таблицы, все работает без нареканий
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7384 / 4806 / 1244
Регистрация: 30.03.2015
Сообщений: 13,633
Записей в блоге: 29
29.10.2020, 11:33
Лучший ответ Сообщение было отмечено MetMark как решение

Решение

Цитата Сообщение от MetMark Посмотреть сообщение
та же ошибка.
я уверен, ты не первый с ней столкнулся, пошерсти английские форумы и СО

Добавлено через 35 секунд
Цитата Сообщение от MetMark Посмотреть сообщение
вероятно где-то накосячил я.
вполне может быть) ну круто что теперь работает
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.10.2020, 11:33
Помогаю со студенческими работами здесь

Lost connection to MySQL server at 'reading initial communication packet', system error: 111
Отправила сайт на хостинг при помощи Filezilla и базу данных импортировала на хостинг, в браузере ввожу адрес сайта, вместо сайта:...

Крашится проект Node JS. Error: Connection lost: The server closed the connection
Пишу бота на Node Js и после пары выполненных команд, бот крашиться с следующей ошибкой: node:events:368 throw er; //...

Mysql.connector.errorsmysql.connector.errors..OperationalErr orOperationalError: : 2055: Lost connection to MySQL
Здравствуйте, писал бота в вк и столкнулся с этими ошибками. Я в тупике( "C:\Users\pk\PycharmProjects\EmaiBot \Scripts\python.exe"...

DLE ошибка, с чего решать MySQL Error! The Error returned was: MySQL server has gone away Error Number 2006
MySQL Error! ------------------------ The Error returned was: MySQL server has gone away Error Number: 2006 ...

Lost connection to MySQL server during query
Написал скрипт, который обращается к удалённой странице через XML и кеширует все данные в MYSQL базу. Скрипт состоит : 1. Подключение к...


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

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

Новые блоги и статьи
Пишем адаптер для локального хранилища S3 на C#
stackOverflow 16.07.2025
Разработка современных приложений часто требует интеграции с объектными хранилищами, и Amazon S3 стал де-факто стандартом в этой области. Однако работа с облачными сервисами в процессе разработки. . .
Старые замки
kumehtar 16.07.2025
Смотрел тут фото, попались пара старых замков. И сразу бросилось в глаза из отличие. Например: Замок Бистон, в англии. Разрушенное сооружение. Но - не испорченное людьми, по крайней мере - на. . .
Java и Eclipse Store: Сверхбыстрые приложения с In-Memory DB
Javaican 15.07.2025
Eclipse Store — это микро-движок персистентности для Java, который позволяет хранить и извлекать нативные Java-объекты без необходимости преобразования данных или использования объектно-реляционного. . .
EmBitz, создание проекта, отладка, прошивка
locm 15.07.2025
Создание проекта для Blue Pill (STM32F103C8T6) в EmBitz 2. 30, написания кода blink, запуск отладки в ОЗУ, заливка релизной прошивки во flash используя ST-Link и др. . . .
Трассировка корутин Kotlin с OpenTelemetry
mobDevWorks 14.07.2025
Асинхронное программирование меняет правила игры, особенно когда речь заходит о трассировке операций. В Kotlin с его корутинами эта проблема приобретает особый оттенок, который я хотел бы детально. . .
Облачные приложения на Rust: руководство по архитектуре микросервисов
golander 13.07.2025
Когда я впервые взялся за проектирование облачной платформы для одного из наших клиентов, выбор стоял между привычными Go и Java. Но после нескольких месяцев разработки микросервисной системы,. . .
Как Node.js выполняет асинхронные операции
Reangularity 13.07.2025
Каждый раз, когда я рассказываю про Node. js, возникает один и тот же вопрос: "Как эта штука может быть быстрой, если JavaScript — однопоточный язык?" И это действительно кажется парадоксом. Ведь в. . .
Как писать чистый, тестируемый и качественный код на Python
py-thonny 12.07.2025
Помню свой первый проект на Python. Работал тогда быстро, грязно, лишь бы работало. Код был похож на запутанный клубок - переменные по одной букве, функции на 200 строк, комментарии отсутствовали как. . .
Blazor и контроллер сервопривода IoT Meadow Maple
Wired 11.07.2025
Я решил разобраться, как можно соединить современные веб-технологии с миром "железа". Интересная комбинация получилась из Blazor в качестве веб-интерфейса и микроконтроллера Meadow с его веб-сервером. . .
Генерация OpenQASM из кода Q#
EggHead 10.07.2025
Летом 2024-го я начал эксперименты с библиотекой Q# Bridge, и знаете что? Она оказалась просто находкой для тех, кто работает на стыке разных квантовых экосистем. Основная фишка этой библиотеки -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru