Heim > Datenbank > MySQL-Tutorial > Wie verwende ich MySQLi-Verbindungen über verschiedene PHP-Klassen hinweg richtig?

Wie verwende ich MySQLi-Verbindungen über verschiedene PHP-Klassen hinweg richtig?

Patricia Arquette
Freigeben: 2024-11-30 06:26:10
Original
638 Leute haben es durchsucht

How to Properly Use MySQLi Connections Across Different PHP Classes?

MySQLi aus einer anderen Klasse in PHP verwenden

Beim Upgrade von PHP 5.6 auf 7.0 ist ein Update von MySQL auf MySQLi erforderlich. Dies kann jedoch manchmal zu Setup-Problemen führen.

Problem:

Nach dem Upgrade auf PHP 7.0 und MySQLi wird versucht, mit $this->db auf Datenbankverbindungen zuzugreifen ->conn führt zu einem internen Serverfehler 500, obwohl die Datenbankverbindung direkt in der Klasse erstellt wird funktioniert.

Lösung:

Der Fehler wird durch mehrere schlechte Praktiken verursacht:

  • Das Erweitern einer Klasse aus der Datenbank ist falsch.
  • Die Datenbankklasse selbst ist nicht nützlich, da sie keine Funktionalität bietet.

Um das zu beheben Problem:

  1. Entfernen Sie die Datenbankklasse.
  2. Erstellen Sie eine einzelne $db-Instanz aus einfachem MySQL.
  3. Übergeben Sie diese Instanz als Konstruktorparameter an jede erforderliche Klasse eine Datenbankverbindung.

Beispiel Code:

// database.php
$db = new mysqli("localhost", "DBUserName", "UserPassword", "SelectedDB");
$db->set_charset('utf8mb4');
Nach dem Login kopieren
// myapi.php
class MyAPI
{
    protected $db;

    public function __construct($db, $request_uri, $postData, $origin)
    {
        $this->db = $db;
    }
    // ... (rest of the class omitted for brevity)
}
Nach dem Login kopieren
// app.php
require 'vendor/autoload.php'; // assuming autoloading is set up

$api = new MyAPI($db, $request_uri, $postData, $origin);
$user = $api->getUser($_POST['id']);
Nach dem Login kopieren

Wenn Sie diese Richtlinien befolgen, können Sie MySQLi erfolgreich aus anderen Klassen in PHP verwenden.

Das obige ist der detaillierte Inhalt vonWie verwende ich MySQLi-Verbindungen über verschiedene PHP-Klassen hinweg richtig?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage