欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP实现基于mysqli的Model基类完整实例

程序员文章站 2024-04-02 08:59:28
本文实例讲述了php实现基于mysqli的model基类。分享给大家供大家参考,具体如下: db.class.php

本文实例讲述了php实现基于mysqli的model基类。分享给大家供大家参考,具体如下:

db.class.php

<?php
  //数据库连接类
  class db {
     //获取对象句柄
     static public function getdb() {
       $_mysqli = new mysqli(db_host,db_user,db_pass,db_name);
       if (mysqli_connect_errno()) {
          echo '数据库连接错误!错误代码:'.mysqli_connect_error();
          exit();
       }
       $_mysqli->set_charset('utf8');
       return $_mysqli;
     }
     //清理,释放资源
     static public function undb(&$_result, &$_db) {
       if (is_object($_result)) {
          $_result->free();
          $_result = null;
       }
       if (is_object($_db)) {
          $_db->close();
          $_db = null;
       }
     }
  }
?>

model.class.php

<?php
  //模型基类
  class model {
     //执行多条sql语句
     public function multi($_sql) {
       $_db = db::getdb();
       $_db->multi_query($_sql);
       db::undb($_result = null, $_db);
       return true;
     }
     //获取下一个增值id模型
     public function nextid($_table) {
       $_sql = "show table status like '$_table'";
       $_object = $this->one($_sql);
       return $_object->auto_increment;
     }
     //查找总记录模型
     protected function total($_sql) {
       $_db = db::getdb();
       $_result = $_db->query($_sql);
       $_total = $_result->fetch_row();
       db::undb($_result, $_db);
       return $_total[0];
     }
     //查找单个数据模型
     protected function one($_sql) {
       $_db = db::getdb();
       $_result = $_db->query($_sql);
       $_objects = $_result->fetch_object();
       db::undb($_result, $_db);
       return tool::htmlstring($_objects);
     }
     //查找多个数据模型
    protected function all($_sql) {
       $_db = db::getdb();
       $_result = $_db->query($_sql);
       $_html = array();
       while (!!$_objects = $_result->fetch_object()) {
          $_html[] = $_objects;
       }
       db::undb($_result, $_db);
       return tool::htmlstring($_html);
     }
     //增删修模型
     protected function aud($_sql) {
       $_db = db::getdb();
       $_db->query($_sql);
       $_affected_rows = $_db->affected_rows;
       db::undb($_result = null, $_db);
       return $_affected_rows;
     }
  }
?>

更多关于php相关内容感兴趣的读者可查看本站专题:《php基于pdo操作数据库技巧总结》、《php运算与运算符用法总结》、《php网络编程技巧总结》、《php基本语法入门教程》、《php操作office文档技巧总结(包括word,excel,access,ppt)》、《php日期与时间用法总结》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家php程序设计有所帮助。