Heim >Backend-Entwicklung >PHP-Tutorial >Ausführliche Erklärung der PHP-gekapselten DB-Klassenverbindung zu SQLite3

Ausführliche Erklärung der PHP-gekapselten DB-Klassenverbindung zu SQLite3

小云云
小云云Original
2017-12-18 15:27:192199Durchsuche

sqlite3_open ist die API-Funktion (C/C++) der SQLite-Datenbank, die zum Öffnen (oder Erstellen) einer Datenbankdatei verwendet wird. Dieser Artikel teilt Ihnen hauptsächlich das Wissen über die PHP-Kapselung der DB-Klasse für die Verbindung mit SQLite3 mit und hofft, allen zu helfen.

<?php
    class dbManager{
        public $db;
        function __construct(){
            if(!file_exists(&#39;./db.php&#39;)){
                $this->init();
                return;
            }
            $this->db = new SQLite3(&#39;./db.php&#39;);
        }
        function init(){
            $this->db = new SQLite3(&#39;./db.php&#39;);
            // TODO:
        }
        function changes(){
            return $this->db->changes();
        }
        function query($sql,$param=null,$memb=null){
            $stmt=$this->db->prepare($sql);
            if(!$stmt)
                return false;
            if($param){
                if(is_array($param)){
                    for($i=0;$i<count($param);$i++)
                        $stmt->bindValue($i+1,$param[$i]);
                }else{
                    $stmt->bindValue(1,$param);
                }
            }
            $rs=$stmt->execute();
            if(!$rs){
                $stmt->close();
                return false;
            }
            $arr=$rs->fetchArray(SQLITE3_NUM);
            $rs->finalize();
            $stmt->close();
            if(!$arr)
                return null;
            if(!$memb)
                return $arr;
            $res=array();
            for($i=0;$i<count($memb);$i++){
                $res[$memb[$i]]=$arr[$i];
            }
            return $res;
        }
        function queryAll($sql,$param=null,$memb=null){
            $stmt=$this->db->prepare($sql);
            if(!$stmt)
                return false;
            if($param){
                if(is_array($param)){
                    for($i=0;$i<count($param);$i++)
                        $stmt->bindValue($i+1,$param[$i]);
                }else{
                    $stmt->bindValue(1,$param);
                }
            }
            $rs=$stmt->execute();
            if(!$rs){
                $stmt->close();
                return false;
            }
            
            $res=array();
            while($arr=$rs->fetchArray(SQLITE3_NUM)){
                if(!$memb) {
                    $res[]=$arr;
                    continue;
                }
                if(count($memb)==1 && $memb[0]==null){
                    $res[]=$arr[0];
                    continue;
                }
                $it=array();
                for($i=0;$i<count($memb);$i++){
                    $it[$memb[$i]]=$arr[$i];
                }
                $res[]=$it;
            }
            $rs->finalize();
            $stmt->close();
            
            return $res;
        }
        function querySingle($sql,$param=null){
            $res=$this->query($sql,$param);
            if(!$res)
                return false;
            return $res[0];
        }
        
        function querySingleAll($sql,$param=null){
            $stmt=$this->db->prepare($sql);
            if(!$stmt)
                return false;
            if($param){
                if(is_array($param)){
                    for($i=0;$i<count($param);$i++)
                        $stmt->bindValue($i+1,$param[$i]);
                }else{
                    $stmt->bindValue(1,$param);
                }
            }
            $rs=$stmt->execute();
            if(!$rs){
                $stmt->close();
                return false;
            }
            
            $res=array();
            while($arr=$rs->fetchArray(SQLITE3_NUM)){
                $res[]=$arr[0];
            }
            $rs->finalize();
            $stmt->close();
            
            return $res;
        }
        function exec($sql,$param=null){
            $stmt=$this->db->prepare($sql);
            if(!$stmt)
                return false;
            if($param){
                if(is_array($param)){
                    for($i=0;$i<count($param);$i++)
                        $stmt->bindValue($i+1,$param[$i]);
                }else{
                    $stmt->bindValue(1,$param);
                }
            }
            $rs=$stmt->execute();
            if($rs) {
                $res=true;
                $rs->finalize();
            }else{
                $res=false;
            }
            $stmt->close();
            return $res;
        }
        
        function begin(){
            return $this->exec(&#39;BEGIN&#39;);
        }
        function rollback(){
            return $this->exec(&#39;ROLLBACK&#39;);
        }
        function commit(){
            return $this->exec(&#39;COMMIT&#39;);
        }
        
        function escapeString($s){
            return $this->db->escapeString($s);
        }
        //最新插入的id
        function lastInsertRowID(){
            return $this->db->lastInsertRowID();
        }
        
        function lastErrorMsg (){
            return $this->db->lastErrorMsg();
        }
    }

?>

PDO unterstützt die Datenbanktransplantation. Wenn Ihre Bereitstellung in Zukunft über mehrere Datenbanken verfügt, verwenden Sie diese gleichzeitig , Die Ausführungseffizienz ist hoch. Es wurde als Erweiterungsbibliothekskomponente von PHP gekapselt. Es läuft schnell und weist eine hohe Effizienz auf

Verwandte Empfehlungen:

Grundlagen von SQLite3 in Python Erläuterung der Operationsbeispiele

Detaillierte Erläuterung des Konfigurationsbeispiels von PHP mit pdo zum Herstellen einer Verbindung zu sqlite3

Aufruf von sqlite3 in PHP

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung der PHP-gekapselten DB-Klassenverbindung zu SQLite3. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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