Nano Hash - криптовалюты, майнинг, программирование

PHP - Лучшая практика Глобальная переменная базы данных в классе (ООП)

Что является «лучшей практикой» в отношении доступа к базе данных, когда у вас есть несколько классов с методами, выполняющими запросы?

Глобальная $db переменная:

$db = new mysqli('localhost', 'my_user', 'my_password', 'my_db');

class Item {
    private $id;

    function __construct($id) {
        $this->id = $id;
    }

    public function remove() {
        global $db;

        // queries and stuff.
    }
}

Или, может быть, передать $db конструктору?

$db = new mysqli('localhost', 'my_user', 'my_password', 'my_db');

$item = new Item(5,$db);

class Item {
    private $id;
    protected $db;

    function __construct($id,$db) {
        $this->id = $id;
        $this->id = $db;
    }

    public function remove() {
        // queries and stuff.
    }
}

Или, может быть, другой способ лучше, чем оба?


Ответы:


1

Для глобальных объектов, которые потенциально можно использовать где угодно, я лично предпочитаю одноэлементные классы:

class DBConnection {

     private static $instance = null;

     private $db;
     private function __construct() {
         $this->db = new mysqli('localhost', 'my_user', 'my_password', 'my_db');
     }

     public static function getDB() {
           if (self::$instance === null) { 
               self::$instance = new self();
           }
           return self::$instance->db;
     }    
}

Таким образом, вы можете просто позвонить: DBConnection::getDB() где угодно, и это также может работать с автоматической загрузкой.

13.04.2016

2

Внедрение конструктора - лучший способ. В классе четко указано, что ему нужен доступ к базе данных. Это поможет поддерживать приложение в долгосрочной перспективе. Вы можете использовать контейнер для внедрения зависимостей (DI или IOC) для автоматического заполнения необходимых сервисов. Существует множество хороших сообщений в блогах об использовании инъекции део-зависимостей в PHP. Документация Symfony хорошо объясняет преимущества.

Глобальные переменные считаются плохой практикой в ​​ООП, и их следует полностью исключить.

Третьей возможностью было бы использование синглтона (что не считается лучшей практикой) или статического фасада, как в более старых версиях Laravel. Статические фасады - горячая тема для обсуждения. Вы можете найти больше о них в документации Laravel.

13.04.2016
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

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

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..