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 ответов

9 просмотров

судя по 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();

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
22
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Карта сайта