php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > SQL / Datenbanken
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


SQL / Datenbanken Probleme mit SQL? Hier könnt ihr eure Fragen zu SQL (MySQL, PostgreSQL, MS-SQL und andere ANSI-SQL Server) los werden.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 02-03-2014, 21:57
Marcoru
 Registrierter Benutzer
Links : Onlinestatus : Marcoru ist offline
Registriert seit: Jun 2012
Beiträge: 38
Marcoru befindet sich auf einem aufstrebenden Ast
Standard Sqlite3 - Prepare Fehler

Hallo,

ich habe eine kleine Klasse geschrieben in der in dem Constructor die Verbindung zur Datenbank hergestellt wird. Doch wenn ich jetzt eine Funktion aufrufen möchte kommt folgender Fehler:
PHP-Code:
SQLite3::prepare(): The SQLite3 object has not been correctly initialised 
Wenn in jeder Funktion die Verbindung zur Datenbank hergestellt wird funktioniert es.
Doch wieso klappt es nicht mit dem Constructor?

Hier der Constructor:
PHP-Code:
if($this->db = new SQLite3(BASE_LIB_DATA md5(BASE_ID "USER"). ".db")) {
            
$sql "CREATE TABLE 
                    IF NOT EXISTS 
                        User (
                            ID INTEGER PRIMARY KEY AUTOINCREMENT, 
                            USER CHAR(30) NOT NULL, 
                            PASSWORD CHAR(30) NOT NULL,
                            PERMGROUP CHAR(30) NOT NULL,
                            REGISTER INTEGER,
                            LASTLOGIN INTEGER 
                            )"
;
            if(
$query $this->db->exec($sql)) {
                return 
true;
            } 
mfg Marco
Mit Zitat antworten
  #2 (permalink)  
Alt 02-03-2014, 22:07
h3ll
 Registrierter Benutzer
Links : Onlinestatus : h3ll ist offline
Registriert seit: Mar 2008
Beiträge: 3.578
h3ll befindet sich auf einem aufstrebenden Ast
Standard

Ein return true macht im Konstruktor keinen Sinn.

Außerdem sollte in einem Konstruktor keine Datenbankverbindung hergestellt werden. Übergib das Datenbankobjekt als Parameter an den Konstruktor.
Mit Zitat antworten
  #3 (permalink)  
Alt 02-03-2014, 22:14
Marcoru
 Registrierter Benutzer
Links : Onlinestatus : Marcoru ist offline
Registriert seit: Jun 2012
Beiträge: 38
Marcoru befindet sich auf einem aufstrebenden Ast
Standard

Hallo,

ok vielen dank für den Tipp!

Mein Konstruktor sieht nun so aus:
PHP-Code:
    public function __construct($sqlite3) {
        if(
$sqlite3 instanceof SQLite3) {
            
$this->db $sqlite3;
        } else {
            
$this->create_error_log("Pfad:" BASE_LIB_DATA " \r\nFehler: .\r\n" $sqliteerror);
        }
    } 
Doch leider immer noch der gleiche Fehler.
Kann man nach einem Prepare Statement noch eins ausführen oder muss man einen Befehl wie reset oder so anwenden?

mfg Marco
Mit Zitat antworten
  #4 (permalink)  
Alt 02-03-2014, 22:16
h3ll
 Registrierter Benutzer
Links : Onlinestatus : h3ll ist offline
Registriert seit: Mar 2008
Beiträge: 3.578
h3ll befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Zitat von Marcoru Beitrag anzeigen
Hallo,

ok vielen dank für den Tipp!

Mein Konstruktor sieht nun so aus:
PHP-Code:
    public function __construct($sqlite3) {
        if(
$sqlite3 instanceof SQLite3) {
            
$this->db $sqlite3;
        } else {
            
$this->create_error_log("Pfad:" BASE_LIB_DATA " \r\nFehler: .\r\n" $sqliteerror);
        }
    } 
Unnötig. Das hier reicht vollkommen:

PHP-Code:
public function __construct(SQLite3 $db) {
    
$this->db $db;

Zitat:
Zitat von Marcoru Beitrag anzeigen
Doch leider immer noch der gleiche Fehler.
Kann man nach einem Prepare Statement noch eins ausführen oder muss man einen Befehl wie reset oder so anwenden?
Was sagt das Handbuch dazu?

Kannst du bitte ein vollständiges Beispiel posten, bei dem dieses Verhalten auftritt?

Geändert von h3ll (02-03-2014 um 22:22 Uhr)
Mit Zitat antworten
  #5 (permalink)  
Alt 02-03-2014, 22:25
Marcoru
 Registrierter Benutzer
Links : Onlinestatus : Marcoru ist offline
Registriert seit: Jun 2012
Beiträge: 38
Marcoru befindet sich auf einem aufstrebenden Ast
Standard

Hallo,

habe es jetzt herausgefunden!
Habe vergessen nach dem Result die Funktion reset aufzurufen.

Vielen Dank!

mfg Marco
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
PHP- Sqlite3 Unable to execute statement Marcoru SQL / Datenbanken 3 15-02-2014 17:28
[PHP5] SQLITE3 und PDO problem dpaehl PHP Developer Forum 7 10-02-2009 16:49
MySQLi Problem Prepare funktioniert nicht norodon PHP Developer Forum 2 12-08-2008 23:26
Mysqli Prepare/Execute > Probleme mit Platzhaltern b0mbe PHP Developer Forum 7 03-04-2008 22:14
SQLite3 Connect Problem Cyberphantom SQL / Datenbanken 5 28-09-2006 15:34

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

ebiz-trader 7.5.0 mit PHP7 Unterstützung veröffentlicht
ebiz-trader 7.5.0 mit PHP7 Unterstützung veröffentlichtDie bekannte Marktplatzsoftware ebiz-trader ist in der Version 7.5.0 veröffentlicht worden.

28.05.2018 | Berni

Wissensbestand in Unternehmen
Wissensbestand in UnternehmenLebenslanges Lernen und Weiterbilden sichert Wissensbestand in Unternehmen

25.05.2018 | Berni


 

Aktuelle PHP Scripte

PHP Server Monitor

PHP Server Monitor ist ein Skript, das prüft, ob Ihre Websites und Server betriebsbereit sind.

11.09.2018 Berni | Kategorie: PHP/ Security
PHP WEB STATISTIK ansehen PHP WEB STATISTIK

Die PHP Web Statistik bietet Ihnen ein einfach zu konfigurierendes Script zur Aufzeichnung und grafischen und textuellen Auswertung der Besuchern Ihrer Webseite. Folgende zeitlichen Module sind verfügbar: Jahr, Monat, Tag, Wochentag, Stunde Folgende son

28.08.2018 phpwebstat | Kategorie: PHP/ Counter
Affilinator - Affilinet XML Produktlisten Skript

Die Affilinator Affilinet XML Edition ist ein vollautomatisches Skript zum einlesen und darstellen der Affili.net (Partnerprogramm Netzwerk) Produktlisten und Produktdaten. Im Grunde gibt der Webmaster seine Affilinet PartnerID ein und hat dann unmittelb

27.08.2018 freefrank@ | Kategorie: PHP/ Partnerprogramme
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 11:10 Uhr.