подражает Ларе, структура папок точно такая же и самописные костыли которые похожи на лару. Так вот мне нужно его допилить и я поставил туда ларовский 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 создаётся второе соединение?
судя по new и твой класс подключения не синглтон, так что каждый раз при вызове методов создается подключение
тебе по-хорошему в своем классе PDO использовать PDO соединение из класс DatabaseManager Laravel, например \Illuminate\Support\Facades\DB::connection()->getPdo(), в случае соединения по умолчанию и тогда у тебя будет одно соединение на весь цикл
Дело в том, что эти типа модели кастомные во всех методах вызывают $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 ]); } Это ли не значит что это подключение каждый раз создаётся для каждого метода модели?
Да другого выхода нет. Я буду юзать ёлку, а это старые модели будут по соединению из ёлки работать. Это я сейчас так понимаю, что если в каждом методе модели как сейчас есть, инстансится новый PDOEx на каждый запрос, значит ли это что каждый раз создаётся подключение?
в случае приведенного мной кода нет в случае твоего класса, да, каждая твоя модель создавала для себя новое соединение
Такая маленькая мысль, что pdo драйвер возможно определяет дубликат соединения и возвращает уже созданное ))
mysql_connect (уже умер), да так и делал, а вот PDO и mysqli делают ли также я не уверен, надо доку смотреть
Но в моём случаи в проекте 100 пользователей * количество запрос = коннектов и запросов
Ибо кодер накодил модельки во всех методах $pdo = new PDOEx();
Обсуждают сегодня