码迷,mamicode.com
首页 > 数据库 > 详细

封装类的方式访问数据库(封装字符串、json)

时间:2016-06-29 18:42:20      阅读:178      评论:0      收藏:0      [点我收藏+]

标签:

<?php
class DBDA
{
    public $host="localhost";//服务器地址
    public $uid="root";//用户名
    public $pwd="";//密码
    
    public $conn;//连接对象
    //操作数据库的方法
    //$sql代表需要执行的SQL语句
    //$type代表SQL语句的类型,1代表查询,0代表增删改
    //$db代表要操作的数据库名称
    //如果是查询,返回二维数组
    //如果是其他语句,返回true或false
    function __construct($db="mydb")
    {
        //造连接对象
        $this->conn = new MySQLi($this->host,$this->uid,$this->pwd,$db);
        //一个属于这个类的对象不能直接调用另一个类的成员,可以在此类中创建那个类的成员变量,该对象调用此成员变量,再调用那个类的方法
    }
    public function Query($sql,$type=1){
        //判断是否出错
        !mysqli_connect_error() or die("连接失败!");
        //执行SQL语句
        $result = $this->conn->Query($sql);
        //判断SQL语句类型
        if($type==1)        {
            //如果是查询语句,返回结果集的二维数组
            return $result->fetch_all();
        }else{
            //如果是其他语句,返回true或false
            return $result;
        }
    }
    
    //Ajax调用返回JSON
    public function JsonQuery($sql,$type=1,$db="mydb"){
        //定义数据源
        $dsn = "mysql:dbname={$db};host={$this->host}";
        //造pdo对象
        $pdo = new PDO($dsn,"{$this->uid}","{$this->pwd}");
        //准备执行SQL语句
        $st = $pdo->prepare($sql);
        //执行预处理SQL语句
        if($st->execute()){
            if($type==1){
                $sttr = $st->fetchAll(PDO::FETCH_ASSOC);
                return json_encode($attr);
            }else{
                if($st){
                    return "OK";
                }else{
                    return "NO";
                }
            }
        }else{
            echo "执行失败!";
        }
    }
    
    //Ajax调用返回字符串
    public function StrQuery($sql,$type=1){
        //判断连接是否成功
        !mysqli_connect_error() or die("连接失败!");
        //执行SQL语句
        $result = $this->conn->query($sql);
        //判断SQL语句类型
        if($type==1){
            $attr = $result->fetch_all();
            $str = "";
            //如果是查询语句返回字符串
            for($i=0;$i<count($attr);$i++){
                for($j=0;$j<count($attr[$i]);$j++){
                    $str = $str.$attr[$i][$j];
                    $str = $str."^";
                }
                $str = substr($str,0,strlen($str)-1);
                $str = $str."|";
            }
            $str = substr($str,0,strlen($str)-1);
            return $str;
        }else{
            //如果是其他语句,返回true或false
            if($result){
                return "OK";
            }else{
                return "NO";
            }
        }
    }
    
    function PdoQuery($sql,$type=1,$db="mydb"){
        //造数据源
        $dns = "mysql:host={$this->host};dbname={$db}";
        //造pdo对象
        $pdo = new PDO($dns,$this->uid,$this->pwd);
        //准备一条SQL语句
        $stm = $pdo->prepare($sql);
        //执行预处理语句
        $r = $stm->execute();
        if($r){
            if($type==1){
                return $stm->fetchAll();
            }else{
                return "OK"; 
            }
        }else{
            return "NO";
        }
    }
}

 

封装类的方式访问数据库(封装字符串、json)

标签:

原文地址:http://www.cnblogs.com/jinshui/p/5627693.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!