成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

php封裝db 類連接sqlite3

alin / 1809人閱讀

摘要:最新插入的支持?jǐn)?shù)據(jù)庫(kù)移植如果你的部署將來(lái)有多種數(shù)據(jù)庫(kù)那就用它了同時(shí)是設(shè)計(jì)的執(zhí)行效率較高他已經(jīng)封裝為的擴(kuò)展庫(kù)組件了運(yùn)行快效率高這是修改為版本的原生類導(dǎo)入的配置文件我這里只是方便前端修改,也可以搞成文件

init();
                return;
            }
            $this->db = new SQLite3("./db.php");
        }
        function init(){
            $this->db = new SQLite3("./db.php");
            // 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;$ibindValue($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;$idb->prepare($sql);
            if(!$stmt)
                return false;
            if($param){
                if(is_array($param)){
                    for($i=0;$ibindValue($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;$ifinalize();
            $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;$ibindValue($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;$ibindValue($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("BEGIN");
        }
        function rollback(){
            return $this->exec("ROLLBACK");
        }
        function commit(){
            return $this->exec("COMMIT");
        }
        
        function escapeString($s){
            return $this->db->escapeString($s);
        }
        //最新插入的id
        function lastInsertRowID(){
            return $this->db->lastInsertRowID();
        }
        
        function lastErrorMsg (){
            return $this->db->lastErrorMsg();
        }
    }
?>

PDO支持?jǐn)?shù)據(jù)庫(kù)移植,如果你的部署將來(lái)有多種數(shù)據(jù)庫(kù),那就用它了.同時(shí),PDO是C設(shè)計(jì)的,執(zhí)行效率較高.他已經(jīng)封裝為PHP的擴(kuò)展庫(kù)組件了.運(yùn)行快,效率高

class dbManager{
    
    function __construct($config) {
        $text = file_get_contents($config);
        $obj = json_decode($text);
        $this->db= new PDO($obj -> dsn, $obj -> user, $obj -> pass);
    }
    
    private function bind_param($stmt,&$param){
        if ($param || $param===0) {
            if (is_array($param)) {
                for ($i = 0; $i < count($param); $i++)
                    $stmt -> bindParam($i + 1, $param[$i]);
            } else {
                $stmt -> bindParam(1, $param);
            }
        }
    }
    
    function exec($sql, $param = null) {
        $stmt = $this -> db -> prepare($sql);
        if (!$stmt){
            var_dump($this->db->errorinfo());
            return false;
        }
        $this->bind_param($stmt,$param);
        $res = $stmt -> execute();
        if($res){
            $res=$stmt->rowCount();
        }
        $stmt -> closeCursor();
        return $res;
    }
    
    function query($sql,$param=null,$name=true){
        $stmt = $this -> db -> prepare($sql);
        if (!$stmt){
            return null;
        }
        $this->bind_param($stmt,$param);
        $res = $stmt -> execute();
        if(!$res){
            $stmt->closeCursor();
            return null;
        }
        $arr=$stmt->fetch($name?PDO::FETCH_ASSOC:PDO::FETCH_NUM);
        $stmt -> closeCursor();
        return $arr;
    }
    
    function queryAll($sql,$param=null,$name=true){
        $stmt = $this -> db -> prepare($sql);
        if (!$stmt){
            return null;
        }
        $this->bind_param($stmt,$param);
        $res = $stmt -> execute();
        if(!$res){
            $stmt->closeCursor();
            return null;
        }
        $arr=$stmt->fetchAll($name?PDO::FETCH_ASSOC:PDO::FETCH_NUM);
        $stmt -> closeCursor();
        return $arr;
    }
    
    function querySingle($sql,$param=null,$name=true){
        $stmt = $this -> db -> prepare($sql);
        if (!$stmt){
            return null;
        }
        $this->bind_param($stmt,$param);
        $res = $stmt -> execute();
        if(!$res){
            $stmt->closeCursor();
            return null;
        }
        $arr=$stmt->fetchColumn();
        $stmt -> closeCursor();
        return $arr;
    }
    
    function querySingleAll($sql,$param=null,$name=true){
        $stmt = $this -> db -> prepare($sql);
        if (!$stmt){
            return null;
        }
        $this->bind_param($stmt,$param);
        $res = $stmt -> execute();
        if(!$res){
            $stmt->closeCursor();
            return null;
        }
        $arr=[];
        do{
            $item=$stmt->fetchColumn();
            if($item)
                $arr[]=$item;
        }while($item!==false);
        $stmt -> closeCursor();
        return $arr;
    }

    public function begin() {
        $this -> db -> beginTransaction();
    }

    public function rollback() {
        $this -> db -> rollBack();
    }

    public function commit() {
        $this -> db -> commit();
    }
}

/*
$db=new dbManager("db.json");
$db->exec("CREATE TABLE USER(ID INTEGER PRIMARY KEY NOT NULL)");
$db->exec("INSERT INTO user(ID) VALUES(?)",1);
var_dump($db->query("SELECT * FROM USER WHERE ID=?",1));
var_dump($db->queryAll("SELECT * FROM USER WHERE ID=?",1));
var_dump($db->querySingle("SELECT * FROM USER WHERE ID=?",1));
var_dump($db->querySingleAll("SELECT * FROM USER WHERE ID=?",1));
*/

?>

這是修改為pdo版本的原生db類
導(dǎo)入的json配置文件
{

"dsn":"sqlite:test.db",
"user":"",
"pass":""

}
我這里只是方便前端修改,也可以搞成php文件

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/26220.html

相關(guān)文章

  • Golang數(shù)據(jù)庫(kù)編程之GORM庫(kù)入門

    摘要:在上一篇文章中我們講解了使用語(yǔ)言的標(biāo)準(zhǔn)庫(kù)包操作數(shù)據(jù)庫(kù)的過(guò)程,雖然使用包操作數(shù)據(jù)也是挺方便的,但是需要自己寫每一條語(yǔ)句,因此我們可能會(huì)自己再度進(jìn)行封裝,以便更好地使用,而使用現(xiàn)有語(yǔ)言開源框架則是代替自己封裝的一個(gè)更好的方式。在上一篇文章中我們講解了使用Go語(yǔ)言的標(biāo)準(zhǔn)庫(kù)sql/database包操作數(shù)據(jù)庫(kù)的過(guò)程,雖然使用sql/database包操作數(shù)據(jù)也是挺方便的,但是需要自己寫每一條SQL語(yǔ)...

    番茄西紅柿 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

alin

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<