hi,欢迎访问本站!
当前位置: 首页编程开发正文

php中使用mysql的类

墨初 编程开发 629阅读

下面写一个在php中调用mysql的类,此mysql类可以连接mysql数据库,并添加数据,删除数据,列出数据等。

php中操作mysql的类

/**
 * @name php mysql类
 * @host https://www.73so.com
 */
class mysql
{
    /**
     * 报错函数
     *
     * @param  string $error
     */
    function err($error){
        die("对不起,您的操作有误,错误原因为:".$error);//die有两种作用 输出和终止 相当于 echo和exit的组合
    }
 
    /**
     * 连接数据库
     *
     * @param string $dbhost  主机名
     * @param string $dbuser  用户名
     * @param string $dbpsw   密码
     * @param string $dbname  数据库名
     * @param string $dbcharset 字符集/编码
     * [url=home.php?mod=space&uid=155549]@Return[/url] bool     连接成功或不成功
     */
    function connect($config){
        extract($config);
        if(!($con = mysql_connect($dbhost,$dbuser,$dbpsw))){//mysql_connect连接数据库函数
            $this->err(mysql_error());
        }
        if(!(mysql_select_db($dbname,$con))){//mysql_select_db选择数据库的函数
            $this->err(mysql_error());
        }
        mysql_query("set names".$dbcharset);//使用mysql_query 设置编码 格式:mysql_query("set names utf8")
 
    }
 
    /**
     * 执行sql语句
     *
     * @param string $sql
     * @return resource 返回执行成功的资源符或执行失败
     */
    function query($sql){
        if(!($query = mysql_query($sql))){
            $this->err($sql."<br />".mysql_error());
        }else{
            return $query;
        }
    }
 
    /**
     * 列表
     *
     * @param resource $query   sql语句通过mysql_query执行出来的资源
     * @return array    返回列表数组
     */
    function findAll($query){
        while($rs = mysql_fetch_array($query,MYSQL_ASSOC)){//mysql_fetch_arrary函数把资源转换成数组,一次转换一行出来
            $list[] = $rs;
        }
       return isset($list)?$list:"";
    }
 
    /**
     * 找到单条数据
     *
     * @param resource $query   sql语句通过mysql_query执行出来的资源
     * @return array    返回单条信息数组
     */
    function findOne($query){
        $rs = mysql_fetch_array($query,MYSQL_ASSOC);
        return $rs;
    }
 
    /**
     * @param resource $query    sql语句通过mysql_query执行出来的资源
     * @param int $row
     * @param int $filed
     * @return 返回指定行的指定字段的值
     */
 
    function findResult($query,$row = 0,$filed = 0){
        $rs = mysql_result($query,$row,$filed);
        return $rs;
 
    }
 
    /**
     * 添加函数
     *
     * @param string $table 表名
     * @param array $arr
     * @return int
     * 添加数组(包含字段和值的一维数组)
     */
    function insert($table,$arr){
        //$sql="insert into 表名(多个字段)values(多个值)"
        foreach ($arr as $key=>$value){
            $value = mysql_real_escape_string($value);
            $keyArr[] = "`".$key."`";//把$arr数组中的键名保存到$keyArr[]数组当中
            $valueArr[] = "`".$value."`";//把$arr数组当中的键值保存到$valueArr当中,因为值多为字符串,而sql语句里面insert当中如果是字符串的话要加单引号,所以这个地方要加上单引号
 
        }
        $keys = implode(",",$keyArr);//implode函数是把数组组合成字符串 implode(分隔符,数组)
        $values = implode(",",$valueArr);
        $sql = "insert into ".$table."(".$keys.")values(".$values.")";
        $this->query($sql);//调用类自身的query(执行)方法执行这条sql语句
        
        return mysql_insert_id();
    }
 
    /**
     * 修改函数
     *
     * @param string $table 表名
     * @param array $arr
     * 修改数组(包含字段和值的一维数组)
     * @param string $where 条件
     */
    function update($table,$arr,$where){
        //update 表名 set 字段=字段值 where....
        foreach ($arr as $key=>$value){
            $value = mysql_real_escape_string($value);
            $keyAndvalueArr[] = "`".$key."`='".$value."'";
            $keyAndvalues = implode(",",$keyAndvalueArr);
            $sql = "update ".$table." set ".$keyAndvalues." where ".$where;//修改操作 格式
            $this->query($sql);
        }
    }
 
 
    /**
     * 删除函数
     *
     * @param string $table 表名
     * @param string $where 条件
     */
    function del($table,$where){
        $sql = "delete from ".$table." where ".$where;//删除sql语句 格式: delete frome 表名 where 条件
        $this->query($sql);
    }
 
}
声明:无特别说明,转载请标明本文来源!
相关推荐