Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
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. Показов 5794. Ответов 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
5042 / 1069 / 149
Регистрация: 29.01.2013
Сообщений: 6,242
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
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 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
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 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
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 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
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 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
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru