Mysqli_query(): сервер MySQL ушел

Я получаю эти ошибки:

Warning: mysqli_query(): MySQL server has gone away in (local db)

Warning: mysqli_query(): Error reading result set's header in (local db)

Сначала я устанавливаю соединение:

$connection = new mysqli($server, $user, $pass, $db) or die("unable");

Тогда это:

$sql = $connection->prepare("INSERT INTO comments (name,mail,homepage,comment,time) VALUES (?,?,?,?,?)");
$sql->bind_Param('sssss',$name,$mail,$homepage,$comment,$time);
$sql->execute();
if ($sql){
  if (!addPics($connection, $image_content, $mime, $time)){
      //other code
  }

addPics выглядит следующим образом:

function addPics($connection, $image_content, $mime, $time){

    $sql = $connection->prepare("INSERT INTO pictures (picture, mime, time)  VALUES (?,?,?)");
    $sql->bind_Param('sss',$image_content,$mime, $time);
    $sql->execute();
    if ($sql){
        return true;
    } else {
        return false;
    }

Ошибка возникает при втором выполнении sql->execute. Я предполагаю, что это потому, что я использую соединение для нескольких запросов, но мои знания PHP не позволяют мне найти решение.

Спасибо!

Спасибо progman за то, что пометил его как дубликат, но это не решило мою проблему увеличения максимально допустимого количества пакетов. Возможно, вы можете помочь чем-то другим, помимо того, чтобы быть школьным наблюдателем?

J. Doe 29.01.2019 23:20

попробуйте освободить объект оператора - т.е. $sql->close(); - также назначьте результат $sql->execute() переменной и проверьте это, а не $sql

Professor Abronsius 29.01.2019 23:20

Спасибо @RamRaider, это решило мою проблему. К сожалению открылся новый..

J. Doe 29.01.2019 23:26
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
3
1 999
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Чтобы продемонстрировать мои комментарии

Было бы разумно использовать обратные кавычки вокруг определенных имен столбцов (или всех), если они имеют особое значение в SQL, например name или time.

$sql = $connection->prepare("INSERT INTO comments (`name`,`mail`,`homepage`,`comment`,`time`) VALUES (?,?,?,?,?)");
$sql->bind_Param('sssss',$name,$mail,$homepage,$comment,$time);


/* assign a variable to the `execute` method and test that var */
$result = $sql->execute();
if ( $result ){

    /* the statement is now finished with, close it */
    $sql->close();


    if (!addPics($connection, $image_content, $mime, $time)){
        //other code
    }

Другие вопросы по теме