加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

php mysql数据库操纵类(实例讲授)

发布时间:2021-02-25 04:37:34 所属栏目:编程 来源:网络整理
导读:接着轻微说嗣魅整体的思绪。整个类的封装,包括一个毗连数据库的私有属性$conn和多少操纵函数。$conn在工具实例化的时辰,由结构函数处理赏罚传入的参数后返回一个资源型的毗连句柄。尔后即可通过挪用该实例化的工具的响应要领对数据库举办增删查改的操纵。 talk l
副问题[/!--empirenews.page--]

接着轻微说嗣魅整体的思绪。整个类的封装,包括一个毗连数据库的私有属性$conn和多少操纵函数。$conn在工具实例化的时辰,由结构函数处理赏罚传入的参数后返回一个资源型的毗连句柄。尔后即可通过挪用该实例化的工具的响应要领对数据库举办增删查改的操纵。

talk less and show code:

* @version 1.0 * @since 2015 */

class Mysql{

//数据库毗连返回值
private $conn;

/**

  • [结构函数,返回值给$conn]
  • @param [string] $hostname [主机名]
  • @param [string] $username[用户名]
  • @param [string] $password[暗码]
  • @param [string] $dbname[数据库名]
  • @param [string] $charset[字符集]
  • @return [null]

*/

function __construct($hostname,$username,$password,$dbname,$charset='utf8'){
  $conn = @mysql_connect($hostname,$password);
  if(!$conn){
    echo '毗连失败,请接洽打点员';
    exit;
  }
  $this->conn = $conn;
  $res = mysql_select_db($dbname);
  if(!$res){
  echo '毗连失败,请接洽打点员';
  exit;
  }
  mysql_set_charset($charset);
}
function __destruct(){
  mysql_close();
}
/**

  • [getAll 获取全部信息]
  • @param [string] $sql [sql语句]
  • @return [array] [返回二维数组]
    */
    function getAll($sql){
      $result = mysql_query($sql,$this->conn);
      $data = array();
      if($result && mysql_num_rows($result)>0){
        while($row = mysql_fetch_assoc($result)){
        $data[] = $row;
        }
      }
      return $data;
    }
    /**
  • [getOne 获取单条数据]
  • @param [string] $sql [sql语句]
  • @return [array] [返回一维数组]
    */
    function getOne($sql){
      $result = mysql_query($sql,$this->conn);
      $data = array();
      if($result && mysql_num_rows($result)>0){
        $data = mysql_fetch_assoc($result);
      }
      return $data;
    }

/**

  • [getOne 获取单条数据]
  • @param [string] $table [表名]
  • @param [string] $data [由字段名当键,属性当键值的一维数组]
  • @return [type] [返回false可能插入数据的id]
    */

function insert($table,$data){
  $str = '';
  $str .="INSERT INTO $table ";
  $str .="(".implode(",",array_keys($data)).") ";
  $str .=" VALUES ";
  $str .= "('".implode("','",$data)."')";
  $res = mysql_query($str,$this->conn);
  if($res && mysql_affected_rows()>0){
      return mysql_insert_id();
  }else{
    return false;
  }
}
/**

  • [update 更新数据库]
  • @param [string] $table [表名]
  • @param [array] $data [更新的数据,由字段名当键,属性当键值的一维数组]
  • @param [string] $where [前提,‘字段名'=‘字段属性']
  • @return [type] [更新乐成返回影响的行数,更新失败返回false]
    */
    function update($table,$data,$where){
      $sql = 'UPDATE '.$table.' SET ';
      foreach($data as $key => $value){
      $sql .= "{$key}='{$value}',";
      }
      $sql = rtrim($sql,',');
      $sql .= " WHERE $where";
      $res = mysql_query($sql,$this->conn);
      if($res && mysql_affected_rows()){
        return mysql_affected_rows();
      }else{
      return false;
      }
    }

/**

  • [delete 删除数据]
  • @param [string] $table [表名]
  • @param [string] $where [前提,‘字段名'=‘字段属性']
  • @return [type] [乐成返回影响的行数,失败返回false]
    */
    function del($table,$where){
      $sql = "DELETE FROM {$table} WHERE {$where}";
      $res = mysql_query($sql,$this->conn);
      if($res && mysql_affected_rows()){
        return mysql_affected_rows();
      }else{
      return false;
      }
    }
    }

    实例化类:

//包括数据库操纵类文件
include 'mysql.class.php';

//配置传入参数
$hostname='localhost';
$username='root';
$password='123456';
$dbname='aisi';
$charset = 'utf8';

//实例化工具

$db = new Mysql($hostname,$dbname);

//获取一条数据

$sql = "SELECT count(as_article_id) as count FROM as_article where as_article_type_id=1";
$count = $db->getOne($sql);

//获取多条数据

$sql = "SELECT * FROM as_article where as_article_type_id=1 order by as_article_addtime desc limit $start,$limit";
$service = $db->getAll($sql);

//插入数据

$arr = array(
'as_article_title'=>'数据库操纵类','as_article_author'=>'rex',);
$res = $db->insert('as_article',$arr);

//更新数据

$arr = array(
'as_article_title'=>'实例化工具','as_article_author'=>'Lee',);
$where = "as_article_id=1";
$res = $db->update('as_article',$arr,$where);

//删除数据

$where = "as_article_id=1";
$res = $db->del('as_article',$where);

?>

演示完代码,或许说几句。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读