Jaqueson Geschrieben 3. August 2006 Teilen Geschrieben 3. August 2006 Hi, ich habe MySQL4 und PHP5 im Einsatz. Jetzt wollte ich eine MySQL Klasse schreiben. Die sieht folgendermaßen aus: Datei db_config.php $host = "localhost"; // MySQL Hostname $database = "Tabelle"; // MySQL Database $db_username = "root"; // MySQL Username $db_pass = "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);[/PHP] Die database_class: [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_connect($this->host.':'.$this->db_port, $this->db_user, $this->db_pass) or die("{connect} Database Error: ".mysql_errno()." : ".mysql_error()); $this->select_database = @ mysql_select_db($this->database, $this->connection) or die("{select_db} Database Error: ".mysql_errno()." : ".mysql_error()); # $this->select_database; } function mysqlclose(){ $this->connection = mysql_close();mysql_pconnect(); } function query($querystring){ if ($this->connection == false) $this->connect(); if ($this->connection == false) return; $res = mysql_query($querystring, $this->connection) or die("{query} Database Error : ".mysql_errno()." : ".mysql_error()); return $res; } } meine Hauptdatei sieht folgendermaßen aus: include ("db_config.php"); // da stehen unsere Daten drinne include ("database_class.php"); // unsere Klasse echo $host, $database, $db_username; $Connection = new mysqlconnection(); $select = $Connection->query("SELECT * FROM Tabelle"); $row = mysql_fetch_object($select); echo $row->spalte;[/PHP] Passwort und Benutzer stimmen, die Tabelle ist ebenso vorhanden. Wenn ich das Skript ausführe kommt folgende Fehlermeldung: {connect} Database Error: 1045 : Access denied for user 'ODBC'@'localhost' (using password: YES) Wenn ich es mit [PHP]mysql_connect("localhost","Benutzer", "PW"); mache geht es. Woran kann das liegen? Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Joe Kinley Geschrieben 3. August 2006 Teilen Geschrieben 3. August 2006 Also erstmal gibst du bei deiner Connect Function den Port mit, und da wo es klappt in deinem seperaten Funktionsaufruf nicht... Ansonsten... schonmal mit PDO probiert? Da gibt es schon eine Klasse die das alles fuer dich macht (aber erst ab 5.1 standardmaessig drin). Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Amstelchen Geschrieben 3. August 2006 Teilen Geschrieben 3. August 2006 $database = "Tabelle"; // MySQL Database $select = $Connection->query("SELECT * FROM Tabelle"); deine datenbank und deine tabelle heissen beide tabelle? s'Amstel Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
oneside Geschrieben 3. August 2006 Teilen Geschrieben 3. August 2006 Das liegt daran, das hier ein Fehler drinnen ist: $this->connection = @mysql_connect($this->host.':'.$this->db_port, $this->db_user, $this->db_pass) or die("{connect} Database Error: ".mysql_errno()." : ".mysql_error()); [/PHP] Die Variable "$this->db_user" gibt es nicht, die muss "$this->db_username" heißen, sonst wird kein Username eingetragen! Gruß - de Oneside - Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Jaqueson Geschrieben 3. August 2006 Autor Teilen Geschrieben 3. August 2006 Thx. Das wars... Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.