MySQL Klasse

In meinem kleinen Tutorial zeige ich euch, wie ihr ganz einfach eine kleine MySQL Klasse schreiben könnt.

MySQL Klasse

Das Tutorial vermittelt euch nicht wie man allgemein mit Klassen umgeht, es dient nur dazu, euch zu zeigen, wie ihr eine
Klasse schreiben könnt, um auf eine MySQL Datenbank zuzugreifen.

Fangen wir auch gleich an!
Zunächst benötigen wir eine Datei, in der die Verbindungsdaten zur MySQL Datenbank stehen.

Legt euch eine Datei an und benennt sie db_config.php

In diese Datei schreibt ihr jetzt folgendes hinein:

<?php
$host 
"localhost"// MySQL Hostname
$database "db123456"// MySQL Database
$db_username "dein_benutzername"// MySQL Username
$db_pass "dein_passwort"// MySQL Password
$db_port "3306"// Port der Datenbank - kann leer gelassen werden, default 3306

define(dbHost$host);
define(db$database);
define(dbUser$db_username);
define(dbPass$db_pass);
define(dbPort$db_port);
?>

Jetzt haben wir die Datei, die die Zugangsdaten der MySQL Datenbank enthält, fertig.
Das define braucht man normalerweise nicht, es hilft aber, den Code im überblick zu behalten ;-)
Kurze Erläuterung:
define(dbHost, $host);
Im PHP Code könnt ihr nun den Inhalt der Variable $host aufrufen, indem wir dbHost eingeben. Alles klar? Dann geht's weiter

Jetzt kommen wir zum eigentlichen Teil, erstellt eine Datei und benennt sie database_class.php
Nun tragt folgendes ein:

<?php
$Connection 
= new mysqlconnection();

class 
mysqlconnection{

}
?>

Unsere Klasse heißt jetzt mysqlconnection; und kann in einem PHP Code aufgerufen werden, in dem man new mysqlconnection();
rein schreibt.
Problem: Wenn man jetzt zig PHP Dateien hat, wo immer diese Klasse benötigt wird, muss man new mysqlconnection(); rein schreiben.
Lösung: Einfach in der database_class.php oben hinein schreiben $Connection = new mysqlconnection();
So wird die Klasse (ich glaub das heißt so) Instantiiert, kurz so könnt ihr später damit umgehen :D

Schreibt jetzt folgendes in eure Classe:

<?php
$Connection 
= new mysqlconnection();
class 
mysqlconnection{

    var 
$host dbHost;
    var 
$database db;
    var 
$db_username dbUser
    var 
$db_pass dbPass
    var 
$db_port dbPort

    function 
connect(){
        
$this->connection = @mysql_pconnect($this->host.':'.$this->db_port$this->db_user$this->db_pass) or die(" Database Error: ".mysql_errno()." : ".mysql_error());
        
$this->select_database = @mysql_select_db($this->database$this->connection) or die(" Database Error: ".mysql_errno()." : ".mysql_error());
    }
}
?>

Oben definieren wir die Variablen $host, $database, $db_username, $db_pass und $db_port und es ist euch sicher aufgefallen, das die Variablen mit den Inhalten gefüllt wird, die wir in db_config.php definiert haben (z.B. define(dbHost, $host); )
Unser Funktion, die zur MySQL Datenbank verbindet, haben wir connect genannt.

$this->connection = @mysql_pconnect($this->host.':'.$this->db_port, $this->db_user, $this->db_pass) or die("
Database Error: ".mysql_errno()." : ".mysql_error());

Hier bauen wir direkt eine Verbindung zur MySQL Datenbank auf und falls das irgend wann aus welchem unempfindlich Grund auch mal nicht gehen sollte, wird weiter hinten ein Fehler ausgegeben.

or die(" Database Error: ".mysql_errno()." : ".mysql_error());

Das soll euch später und den Usern, die euer Script benutzen, helfen, Fehler zu finden. Wenn also mal ein User an kommt und rumheult, weil euer Script den Dienst verweigert, so kann ich der User gleich die Fehlermeldung mitteilen. Und anhand des seht ihr dann noch eher, das was mit den Verbindgungsdaten nicht stimmt.
Genug der redet, weiter geht's! Schreibt nun folgendes in eure database_class.php Datei:

<?php
$Connection 
= new mysqlconnection();
class 
mysqlconnection{

    var 
$host dbHost;
    var 
$database db;
    var 
$db_username dbUser
    var 
$db_pass dbPass
    var 
$db_port dbPort

    function 
connect(){
        
$this->connection = @mysql_pconnect($this->host.':'.$this->db_port$this->db_user$this->db_pass) or die(" Database Error: ".mysql_errno()." : ".mysql_error());
        
$this->select_database = @mysql_select_db($this->database$this->connection) or die(" Database Error: ".mysql_errno()." : ".mysql_error());
        
# $this->select_database;
    
}

    function 
mysqlclose()
    {
        
$this->connection mysql_close();
    }
}
?>

Wir haben unsere kleine Klasse um die Funktion mysqlclose() erweitert.
Diese Funktion schließt beim Aufrufen eure MySQL Verbindung.
Normalerweise bräuchtet ihr diese Funktion nicht, da in der Regel beim beenden des Scripts auch die Verbindung geschlossen wird.

Schreibt nun folgendes in eure database_class.php Datei:

<?php
$Connection 
= new mysqlconnection();
class 
mysqlconnection{

    var 
$host dbHost;
    var 
$database db;
    var 
$db_username dbUser
    var 
$db_pass dbPass
    var 
$db_port dbPort

    function 
connect(){
        
$this->connection = @mysql_pconnect($this->host.':'.$this->db_port$this->db_user$this->db_pass) or die(" Database Error: ".mysql_errno()." : ".mysql_error());
        
$this->select_database = @mysql_select_db($this->database$this->connection) or die(" Database Error: ".mysql_errno()." : ".mysql_error());
        
# $this->select_database;
    
}

    function 
mysqlclose(){
        
$this->connection mysql_close();
    }

    function 
query($querystring){
        if (
$this->connection == false$this->connect();
        if (
$this->connection == false) return;
        
$res mysql_query($querystring$this->connection) or die(" Database Error : ".mysql_errno()." : ".mysql_error());
    return 
$res;
    }
}
?>

Nun gibt es die Funktion query in unserer Klasse.
Kurze Erläuterung:
$res = mysql_query($querystring, $this->connection) or die(" Database Error : ".mysql_errno()." : ".mysql_error());

$querystring wird später übergeben, darin wird dann so was stehen wie z.B. "SELECT * FROM table". Hinten haben wir für die Fehlerausgabe drinstehen. Was das da soll habe ich ja oben schon erklärt ;-)
So, fertig währe unsere kleine MySQL Klasse. Wie ihr das ganze jetzt aufruft, sag ich euch ein andere mal :D

Spaß beiseite, erstellt eine neue Datei und nennt sie test.php
Schreibt folgendes in die Datei:

<?php
include ("db_config.php"); // da stehen unsere Daten drinne
include ("database_class.php"); // unsere Klasse
$select $Connection->query("SELECT * FROM table");
$row mysql_fetch_object($select);
echo 
$row->spalten_nam
?>

Erläuterung:
Unsere Klasse und deren Funktionen rufen wir so auf:
$Connection->funktionsname

Die Variable $Connection wird in der database_class.php "gefüllt" (Wisst ihr noch? $Connection = new mysqlconnection(); )

$select = $Connection->query("SELECT * FROM table");
$select ruft jetzt die Funktion query() auf, der Querystring ($querystring) ist "SELECT * FROM table".

$row = mysql_fetch_array($select); "hohlt" sich jetzt den Inhalt, ausgeben und/oder verwenden tut ihr das so:
$row->spalten_name

Fertig!

Das war's auch schon, ich hoffe ihr habt alles soweit verstanden, bei Fragen einfach in das Forum gehen.
Gruß euer benny-one

Ratings

There are no comments available yet.

Here you can write a comment


Please enter at least 10 characters.
Loading... Please wait.
* Pflichtangabe

Related topics

Definition of stored procedures - an introduction

Stored procedures are predefined SQL code blocks that are stored in a database and can be called up as required. ...

Bernie

Autor : ebiz-consult GmbH & Co. KG
Category: mySQL-Tutorials

Gästebuch mit Datenbankanbindung

Dieses Tutorial beschreibt ausführlich wie ein Gästebuch in PHP und mySQL programmiert wird. ...

andy@

Autor : andy@
Category: PHP-Tutorials

Einfaches News-Script

Das hier ist ein kleines Tutorial, um zu zeigen wie so ein News-Script aussehen kann. Im Grunde ist es nichts anderes als ein Gästebuch, in welches jedoch nur der Webmaster (oder sonstige authorisierte Personen) etwas eintragen kann. Natürlich kann man ...

pik

Autor : pik
Category: PHP-Tutorials

Hier ein kleines allgemeines Tutorial zu PHP

Die Einleitung ist in folgende Themen aufgeteilt: -Einleitung -Variablen -Parameterübergabe -Funktionen -Schleifen -IF-Abfragen Am besten Sie schauen sie sich der Reihenfolge nach an. ...

demiangrandt@

Autor : demiangrandt@
Category: PHP-Tutorials

Datenbankinhalt für Suchmaschinen aufbereiten

Sie haben eine Datenbankanwendung geschrieben und keiner weiß, welche Daten bei Ihnen zu finden sind. Suchmaschinen gehen natürlich nicht so weit, daß sie Abfragen an die Datenbank senden. Somit bleibt der Inhalt Ihrer Tabelle für Suchmaschinen unsichtbar ...

Wolfgang13

Autor : Wolfgang13
Category: SEO Tutorials

plotting masters - a professional guide - Teil II

Grafische Interpolation und Bestapproximation von numerischen Wertepaaren: Wir wollen Punkte auf einer Zeichenebene über verschiedene Verfahren miteinander verbinden. ...

EVAMasters

Autor : EVAMasters
Category: PHP-Tutorials

Gästebuch mit Datenbankanbindung

Dieses Tutorial beschreibt ausführlich wie ein Gästebuch in PHP und mySQL programmiert wird. ...

andy@

Autor : andy@
Category: PHP-Tutorials

How to effectively perform complex queries with SQL queries in MySQLi?

This MySQL tutorial explains how to efficiently perform complex SQL queries in MySQLi. We will look at various aspects of database querying and learn specific methods to fully utilise the power of MySQLi. ...

TheMax

Autor : TheMax
Category: mySQL-Tutorials

Publish a tutorial

Share your knowledge with other developers worldwide

Share your knowledge with other developers worldwide

You are a professional in your field and want to share your knowledge, then sign up now and share it with our PHP community

learn more

Publish a tutorial