WedX - журнал о программировании и компьютерных науках

Автоматическое закрытие php-соединений с mysql

У меня слишком много подключений к mysql в моем php-скрипте. Соединения не закрываются - возможно, я забыл закрыть в некоторых местах своего кода.

Есть ли способ определить sql для автоматического закрытия всех моих php-соединений с сервером в конце скрипта?

23.02.2016

  • попробуйте это, $link = mysql_connect('localhost', 'mysql_user', 'mysql_password'); if (!$link) { die('Не удалось подключиться: ' .mysql_error()); } echo 'Подключение успешно'; mysql_close ($ ссылка); 23.02.2016

Ответы:


1

Вы можете определить класс для управления соединением mysql, как это

class MysqlConnection
{
    private $connection;

    public function __construct()
    {
        $this->connection = mysqli_connect();
    }

    public function __destruct()
    {
        mysqli_close($this->connection);
    }

}

Когда скрипт запустится до конца, php уничтожит все объекты, а затем автоматически вызовет деструктор. Таким образом, соединение также может быть закрыто.

23.02.2016

2

Если вы не используете постоянные соединения, PHP автоматически закрывает все соединения с MySQL, когда сценарий завершается.

Из руководства.

Открытые непостоянные соединения MySQL и наборы результатов автоматически уничтожаются, когда PHP-скрипт завершает свое выполнение.

23.02.2016

3

Я нашел проблему. Я не использовал постоянные соединения, поэтому предполагалось, что соединение будет закрыто, когда скрипт завершится.

Однако я использовал сторонний код с именем «prototype.js». Я не знаю почему, но это блокировало мой код от закрытия php-соединений. После того, как я удалил следующую строку, все заработало нормально.

<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/prototype/1.7.3.0/prototype.js"></script>
26.02.2016
Новые материалы

Как создать диаграмму градиентной кисти с помощью D3.js
Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


Для любых предложений по сайту: [email protected]