<?php
header('content-type:text/html;charset=utf-8');
//封装mysql   连接数据库php_mysql
//封装mysql   连接数据库php_mysqli
//封装mysql   连接数据库php_pdo
class db{
    //三私一共
    //私有的静态属性
    private static $dbcon = false; //存储数据库连接对象
    //私有的构造方法
    private function __construct(){
        //创建链接
        $dbcon=mysql_connect('127.0.0.1','root','root');
        //选择数据库
        mysql_select_db('yii_back',$dbcon) or die('mysql connect error');
        //设置字符集
        mysql_query('set names utf8');
    }
    //私有的clone
    private function __clone(){}
    //共有的静态方法
    public static function getInstance(){
        if(self::$dbcon == false){
            self::$dbcon = new self;
        }
        return self::$dbcon;
    }

/**
    *执行sql语句
    *@param $sql
    *@return source
    **/
    public function query($sql){
        //通过mysql_query来实现
        $query = mysql_query($sql);
        
        //返回执行结果
        return $query;
    }

/**
     * 查询某个字段  eg:  select  name  select count(*)
     *@param $sql
     *@return string or int
    **/
    public function getOne($sql){
        $query=$this->query($sql);
        //有可能出现错误
        if(!$query){
            //SQL语句有错
            echo 'SQL语句错误!<br/>';
            echo '错误编号:' . mysql_errno() . '<br/>';
            echo '错误原因:' . mysql_error() . '<br/>';
            exit;
        }    
        return mysql_result($query,0);
    }

/**
     * 查询一行记录
     *@param $sql
     *@return array 一维数组
     *mysql_fetch_assoc  mysql_fetch_array  mysql_fetch_row
    **/
    public function getRow($sql,$type="assoc"){
        $query=$this->query($sql);
        if(!in_array($type,array('assoc','array','row'))){
            die('mysql_query error!');
        }
        $funcname = "mysql_fetch_".$type;
        return $funcname($query);
    }

/**
     * 查询多条记录
     *@param $sql
     *@return array 二维数组
     *mysql_fetch_assoc  mysql_fetch_array  mysql_fetch_row
    **/
    public function getAll($sql){
        //调用sql 执行函数
        $query=$this->query($sql);
        $list=array();
        //遍历结果
        //while($arr = $this->getRowFromSource($query)){
        while($arr = mysql_fetch_assoc($query)){
            $list[]=$arr;
        }
        return $list;
    }

/**
     * 获得上一次插入的id
    **/
    public function getInsertId(){
        return mysql_insert_id();
    }

/**
     * 新增数据方法
     * @param1 string $sql,要执行的SQL语句
     * @param1 array  $data,要添加的数据
     * @return 自增长id
    **/
    public function insert($table,$data=array()){  
        //print_r($data);die;
        $sql="insert into ".$table."(".implode(',',array_keys($data)).") values ('".implode("','",array_values($data))."')";
        //调用sql 执行函数
        $query=$this->query($sql);
        if($query){
            //返回数据
            return mysql_insert_id();  //得到上次操作的自增长ID
        }else{
            return $sql;
        }
    }

/**
     * 修改数据方法
     * @param string $table 操作的数据表名
     * @param array $data 操作的数据
     * @param array $condition 条件
    **/
    public function update($table,$data,$condition=array()){
        $where='';
        if(!empty($condition)){   
            foreach($condition as $k=>$v){
                $where.=$k."='".$v."' and ";
            }
            $where='where '.$where .'1=1';
        }
        $updatastr = '';
        if(!empty($data)){
            foreach($data as $k=>$v){
                $updatastr.= $k."='".$v."',";
            }
            $updatastr = 'set '.rtrim($updatastr,',');
        }
        $sql = "update {$table} {$updatastr} {$where}";
        $query=$this->query($sql);
        if($query){
            echo '修改成功';
        }else{
            return $sql;
        }
    }

/**
     * 删除数据方法
     * @param string $table 操作的数据表名
     * @param array  $condition 删除的条件
     */
    public function delete($table,$condition){
        $where='';
        if(!empty($condition)){     
            foreach($condition as $k=>$v){
                $where.=$k."='".$v."' and ";
            }
            $where='where '.$where .'1=1';
        }
        $sql="delete from {$table} {$where}";
        $query=$this->query($sql);
        if($query){
            echo '删除成功';
        }else{
            return $sql;
        }
    }

/**
     * 查询数据方法
     * @param string $table 操作的数据表名
     * @param array  $condition 查询的条件
     * @param array  $field     要查询的字段
     */
    public function select($table,$condition=array(),$field = array()){
        $where='';
        if(!empty($condition)){
             
            foreach($condition as $k=>$v){
                $where.=$k."='".$v."' and ";
            }
            $where='where '.$where .'1=1';
        }
        $fieldstr = '';
        if(!empty($field)){
            foreach($field as $k=>$v){
                $fieldstr.= $v.',';
            }
            $fieldstr = rtrim($fieldstr,',');
        }else{
            $fieldstr = '*';
        }
        $sql = "select {$fieldstr} from {$table} {$where}";
        $query=$this->query($sql);
        $resultRow = array();
        $i = 0;
        while($row=mysql_fetch_assoc($query)){
            foreach($row as $k=>$v){
                $resultRow[$i][$k] = $v;
            }
            $i++;
        }
        return $resultRow;
    }
}

php 封装mysql 数据库操作类的更多相关文章

  1. php 封装Mysql数据库操作类

    花了点时间写了个基于php5.3的Mysql类 $mysql = new Mysql('host','user','pass','db') bool Mysql::insert("表&quo ...

  2. php : mysql数据库操作类演示

    设计目标: 1,该类一实例化,就可以自动连接上mysql数据库: 2,该类可以单独去设定要使用的连接编码(set names XXX) 3,该类可以单独去设定要使用的数据库(use XXX): 4,可 ...

  3. php MySQL数据库操作类源代码

    php MySQL数据库操作类源代码: <?php class MySQL{ private $host; //服务器地址 private $name; //登录账号 private $pwd; ...

  4. 设计模式 - 单例模式mysql数据库操作类

    待续... index.php 调用方法: <?php header('Content-Type:text/html; charset=utf8'); require 'instance.php ...

  5. MySQL数据库操作类(PHP实现,支持连贯操作)

    <?php /** * Author: suvan * CreateTime: 2018/2/27 * description: 数据库操作类(仅对接MySQL数据库,主要利用MySQLi函数) ...

  6. php pdo mysql数据库操作类

    <?php namespace iphp\core; use iphp\App; /** * 数据库操作基类 基于pdo * @author xuen * 支持链式操作,支持参数绑定 * 说明1 ...

  7. C# MySQL 数据库操作类

    using System; using System.Configuration; using System.Collections; using System.Data; using MySql.D ...

  8. DELPHI XE MYSQL数据库操作类 MYSQLHELPER

    注: 无需odbc配置 {* * MySQL Helper v1.0 * 2015.6.19 * 说明: * 这是一个操作MySQL的类,该类必须和libmysql.dll,dbxmys.dll两个文 ...

  9. php中用面向对象的思想编写mysql数据库操作类

    最近刚入门完mysql,正好学了一阵子php就想着如何把mysql的表信息用php打印页面上.现在就把代码贴出来,以便小伙伴们参考. 先是建立mysql连接: /*建立连接*/ class datab ...

随机推荐

  1. phpstrom 编辑器设置

    http://www.jb51.net/article/58069.htm 配置sublime主题  保存配置的路径为:C:\Users\Administrator\.WebIde100\config ...

  2. Linux-以指定用户运行redis

    redis中无配置启动用户信息,需要添加redis用户,后以其启动 useradd -s /bash/false -M redis >& &

  3. 大白话系列之C#委托与事件讲解(二)

    什么是事件?EVENT?点击事件?加载事件?一连串的模糊的概念冲击着我们弱小的脑袋 那我们首先来看一下比较正统的感念吧: 事件是类在发生其关注的事情时用来提供通知的一种方式. 事件的发生一般都牵扯2个 ...

  4. PostgreSQL Hardware Performance Tuning

    Bruce Momjian POSTGRESQL is an object-relational database developed on the Internet by a group of de ...

  5. Python中strip()函数

    在python API中这样解释strip()函数:

  6. js 动态 activex 组件

    function writeObject(){ var obj = document.getElementById("mydelphi"); if(!obj){ var divob ...

  7. winform 调用http 通过代理出现的一系列问题

    如果遇到以上问题,请拷贝以下代码到你的桌面应用程序的app.config 文件中 <system.net> <defaultProxy enabled="false&quo ...

  8. JavaScript中类的实现机制

    理解类的实现机制在前面已经讲过,在JavaScript中可以使用function关键字来定义一个“类”.现在介绍如何为类添加成员.其过程很简单,在函数内通过this指针引用的变量或者方法都会成为类的成 ...

  9. css之padding,marging

    padding:内边距,所有浏览器都支持,不允许使用负值 继承内部格式生成了10px的边距. 属性: auto:浏览器计算机内边距. length:规定以具体单位计的内边距值,比如像素.厘米等.默认值 ...

  10. JVM通过代理服务器连接网络的参数设置

    -DproxySet=true-Dhttp.proxyHost=your.proxy.net-Dhttp.proxyPort=8080