169 похожих чатов

Приветствую. У меня тут проект написан на пыхе, который очень

подражает Ларе, структура папок точно такая же и самописные костыли которые похожи на лару. Так вот мне нужно его допилить и я поставил туда ларовский eloquent https://github.com/laravel/framework/tree/9.x/src/Illuminate/Database

Дело в том, что тут уже есть подключение к БД и так называемые модели которые в каждом методе создают PDO класс.
Например:

public static function findBy( $value,string $column)
{
$pdo = new PDOEx();
$stmt = $pdo->prepare("SELECT * FROM `" . static::TABLE . "` WHERE `{$column}` = :value");
$stmt->execute(['value' => $value]);

Так вот если я подключаю eloquent создаётся второе соединение?

9 ответов

16 просмотров

судя по new и твой класс подключения не синглтон, так что каждый раз при вызове методов создается подключение

тебе по-хорошему в своем классе PDO использовать PDO соединение из класс DatabaseManager Laravel, например \Illuminate\Support\Facades\DB::connection()->getPdo(), в случае соединения по умолчанию и тогда у тебя будет одно соединение на весь цикл

Stork- Автор вопроса
Egor Gruzdev
тебе по-хорошему в своем классе PDO использовать P...

Дело в том, что эти типа модели кастомные во всех методах вызывают $pdo = new PDOEx(); который наследует PDO и в конструкторе создаёт подключение function __construct() { @parent::__construct(DB_CONF, DB_USER, DB_PASSWORD, [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_EMULATE_PREPARES => false, PDO::MYSQL_ATTR_INIT_COMMAND=>"SET NAMES UTF8", PDO::ATTR_PERSISTENT => false ]); } Это ли не значит что это подключение каждый раз создаётся для каждого метода модели?

Stork- Автор вопроса

Да другого выхода нет. Я буду юзать ёлку, а это старые модели будут по соединению из ёлки работать. Это я сейчас так понимаю, что если в каждом методе модели как сейчас есть, инстансится новый PDOEx на каждый запрос, значит ли это что каждый раз создаётся подключение?

Stork
Да другого выхода нет. Я буду юзать ёлку, а это ст...

в случае приведенного мной кода нет в случае твоего класса, да, каждая твоя модель создавала для себя новое соединение

Stork- Автор вопроса

Такая маленькая мысль, что pdo драйвер возможно определяет дубликат соединения и возвращает уже созданное ))

Stork
Такая маленькая мысль, что pdo драйвер возможно оп...

mysql_connect (уже умер), да так и делал, а вот PDO и mysqli делают ли также я не уверен, надо доку смотреть

Stork- Автор вопроса

Но в моём случаи в проекте 100 пользователей * количество запрос = коннектов и запросов

Stork- Автор вопроса
Stork
Но в моём случаи в проекте 100 пользователей * кол...

Ибо кодер накодил модельки во всех методах $pdo = new PDOEx();

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта