php mysql数据库操作类


Posted in PHP onJune 04, 2008
<?php 
/* 
 *    mysql数据库 DB类 
 *    @package    db 
 *    @author        yytcpt(无影) 
 *    @version    2008-03-27 
 *    @copyrigth    http://www.d5s.cn/  
 */ 
class db { 
    var $connection_id = ""; 
    var $pconnect = 0; 
    var $shutdown_queries = array(); 
    var $queries = array(); 
    var $query_id = ""; 
    var $query_count = 0; 
    var $record_row = array(); 
    var $failed = 0; 
    var $halt = ""; 
    var $query_log = array(); 
    function connect($db_config){ 
        if ($this->pconnect){ 
            $this->connection_id = mysql_pconnect($db_config["hostname"], $db_config["username"], $db_config["password"]); 
        }else{ 
            $this->connection_id = mysql_connect($db_config["hostname"], $db_config["username"], $db_config["password"]); 
        } 
        if ( ! $this->connection_id ){ 
            $this->halt("Can not connect MySQL Server"); 
        } 
        if ( ! @mysql_select_db($db_config["database"], $this->connection_id) ){ 
            $this->halt("Can not connect MySQL Database"); 
        } 
        if ($db_config["charset"]) { 
            @mysql_unbuffered_query("SET NAMES '".$db_config["charset"]."'"); 
        } 
        return true; 
    } 
    //发送SQL 查询,并返回结果集 
    function query($query_id, $query_type='mysql_query'){ 
        $this->query_id = $query_type($query_id, $this->connection_id); 
        $this->queries[] = $query_id; 
        if (! $this->query_id ) { 
            $this->halt("查询失败:\n$query_id"); 
        } 
        $this->query_count++; 
        $this->query_log[] = $str; 
        return $this->query_id; 
    } 
    //发送SQL 查询,并不获取和缓存结果的行 
    function query_unbuffered($sql=""){ 
        return $this->query($sql, 'mysql_unbuffered_query'); 
    } 
    //从结果集中取得一行作为关联数组 
    function fetch_array($sql = ""){ 
        if ($sql == "") $sql = $this->query_id; 
        $this->record_row = @mysql_fetch_array($sql, MYSQL_ASSOC); 
        return $this->record_row; 
    } 
    function shutdown_query($query_id = ""){ 
        $this->shutdown_queries[] = $query_id; 
    } 
    //取得结果集中行的数目,仅对 INSERT,UPDATE 或者 DELETE 
    function affected_rows() { 
        return @mysql_affected_rows($this->connection_id); 
    } 
    //取得结果集中行的数目,仅对 SELECT 语句有效 
    function num_rows($query_id="") { 
        if ($query_id == "") $query_id = $this->query_id; 
        return @mysql_num_rows($query_id); 
    } 
    //返回上一个 MySQL 操作中的错误信息的数字编码 
    function get_errno(){ 
        $this->errno = @mysql_errno($this->connection_id); 
        return $this->errno; 
    } 
    //取得上一步 INSERT 操作产生的 ID 
    function insert_id(){ 
        return @mysql_insert_id($this->connection_id); 
    } 
    //得到查询次数 
    function query_count() { 
        return $this->query_count; 
    } 
    //释放结果内存 
    function free_result($query_id=""){ 
           if ($query_id == "") $query_id = $this->query_id; 
        @mysql_free_result($query_id); 
    } 
    //关闭 MySQL 连接 
    function close_db(){ 
        if ( $this->connection_id ) return @mysql_close( $this->connection_id ); 
    } 
    //列出 MySQL 数据库中的表 
    function get_table_names(){ 
        global $db_config; 
        $result = mysql_list_tables($db_config["database"]); 
        $num_tables = @mysql_numrows($result); 
        for ($i = 0; $i < $num_tables; $i++) { 
            $tables[] = mysql_tablename($result, $i); 
        } 
        mysql_free_result($result); 
        return $tables; 
       } 
    //从结果集中取得列信息并作为对象返回,取得所有字段 
    function get_result_fields($query_id=""){ 
           if ($query_id == "") $query_id = $this->query_id; 
        while ($field = mysql_fetch_field($query_id)) { 
            $fields[] = $field; 
        } 
        return $fields; 
       } 
    //错误提示 
    function halt($the_error=""){ 
        $message = $the_error."<br/>\r\n"; 
        $message.= $this->get_errno() . "<br/>\r\n"; 
        $sql = "INSERT INTO `db_error`(pagename, errstr, timer) VALUES('".$_SERVER["PHP_SELF"]."', '".addslashes($message)."', ".time().")"; 
        @mysql_unbuffered_query($sql); 
        if (DEBUG==true){ 
            echo "<html><head><title>MySQL 数据库错误</title>"; 
            echo "<style type=\"text/css\"><!--.error { font: 11px tahoma, verdana, arial, sans-serif, simsun; }--></style></head>\r\n"; 
            echo "<body>\r\n"; 
            echo "<blockquote>\r\n"; 
            echo "<textarea class=\"error\" rows=\"15\" cols=\"100\" wrap=\"on\" >" . htmlspecialchars($message) . "</textarea>\r\n"; 
            echo "</blockquote>\r\n</body></html>"; 
            exit; 
        } 
    } 
    function __destruct(){ 
        $this->shutdown_queries = array(); 
        $this->close_db(); 
    } 
    function sql_select($tbname, $where="", $limit=0, $fields="*", $orderby="id", $sort="DESC"){ 
        $sql = "SELECT ".$fields." FROM `".$tbname."` ".($where?" WHERE ".$where:"")." ORDER BY ".$orderby." ".$sort.($limit ? " limit ".$limit:""); 
        return $sql; 
    } 
    function sql_insert($tbname, $row){ 
        foreach ($row as $key=>$value) { 
            $sqlfield .= $key.","; 
            $sqlvalue .= "'".$value."',"; 
        } 
        return "INSERT INTO `".$tbname."`(".substr($sqlfield, 0, -1).") VALUES (".substr($sqlvalue, 0, -1).")"; 
    } 
    function sql_update($tbname, $row, $where){ 
        foreach ($row as $key=>$value) { 
            $sqlud .= $key."= '".$value."',"; 
        } 
        return "UPDATE `".$tbname."` SET ".substr($sqlud, 0, -1)." WHERE ".$where; 
    } 
    function sql_delete($tbname, $where){ 
        return "DELETE FROM `".$tbname."` WHERE ".$where; 
    } 
    //新增加一条记录 
    function row_insert($tbname, $row){ 
        $sql = $this->sql_insert($tbname, $row); 
        return $this->query_unbuffered($sql); 
    } 
    //更新指定记录 
    function row_update($tbname, $row, $where){ 
        $sql = $this->sql_update($tbname, $row, $where); 
        return $this->query_unbuffered($sql); 
    } 
    //删除满足条件的记录 
    function row_delete($tbname, $where){ 
        $sql = $this->sql_delete($tbname, $where); 
        return $this->query_unbuffered($sql); 
    } 
    /*    根据条件查询,返回所有记录 
     *    $tbname 表名, $where 查询条件, $limit 返回记录, $fields 返回字段 
     */ 
    function row_select($tbname, $where="", $limit=0, $fields="*", $orderby="id", $sort="DESC"){ 
        $sql = $this->sql_select($tbname, $where, $limit, $fields, $orderby, $sort); 
        return $this->row_query($sql); 
    } 
    //详细显示一条记录 
    function row_select_one($tbname, $where, $fields="*", $orderby="id"){ 
        $sql = $this->sql_select($tbname, $where, 1, $fields, $orderby); 
        return $this->row_query_one($sql); 
    } 
    function row_query($sql){ 
        $rs     = $this->query($sql); 
        $rs_num = $this->num_rows($rs); 
        $rows = array(); 
        for($i=0; $i<$rs_num; $i++){ 
            $rows[] = $this->fetch_array($rs); 
        } 
        $this->free_result($rs); 
        return $rows; 
    } 
    function row_query_one($sql){ 
        $rs     = $this->query($sql); 
        $row = $this->fetch_array($rs); 
        $this->free_result($rs); 
        return $row; 
    } 
    //计数统计 
    function row_count($tbname, $where=""){ 
        $sql = "SELECT count(id) as row_sum FROM `".$tbname."` ".($where?" WHERE ".$where:""); 
        $row = $this->row_query_one($sql); 
        return $row["row_sum"]; 
    } 
} 
?>

很久没有发帖了,把我常用的一些php类文件分享出来。
如果您加了新功能,或者是有改进,请与大家一起分享。
<?php 
    $db_config["hostname"]    = "127.0.0.1";    //服务器地址 
    $db_config["username"]    = "root";        //数据库用户名 
    $db_config["password"]    = "root";        //数据库密码 
    $db_config["database"]    = "wap_blueidea_com";        //数据库名称 
    $db_config["charset"]        = "utf8"; 
    include('db.php'); 
    $db    = new db(); 
    $db->connect($db_config); 
    //例:查询表 table_name 中 cid=1的所有记录。 
    $row = $db->row_select('table_name', 'cid=1'); 
?>

更详细的使用方法,请参考 db类文件中的注释。 
PHP 相关文章推荐
php sprintf()函数让你的sql操作更安全
Jul 23 PHP
PHP 文件上传全攻略
Apr 28 PHP
采集邮箱的php代码(抓取网页中的邮箱地址)
Jul 17 PHP
PHP获取网址的顶级域名函数代码
Sep 24 PHP
解析php中用PHPMailer来发送邮件的示例(126.com的例子)
Jun 24 PHP
php代码审计比较有意思的例子
May 07 PHP
php实现Linux服务器木马排查及加固功能
Dec 29 PHP
分享10段PHP常用代码
Nov 11 PHP
使用PHP uniqid函数生成唯一ID
Nov 18 PHP
使用symfony命令创建项目的方法
Mar 17 PHP
php  PATH_SEPARATOR判断当前服务器系统类型实例
Oct 28 PHP
TP5框架实现上传多张图片的方法分析
Mar 29 PHP
CodeIgniter php mvc框架 中国网站
May 26 #PHP
五个PHP程序员工具
May 26 #PHP
需要使用php模板的朋友必看的很多个顶级PHP模板引擎比较分析
May 26 #PHP
JS实现php的伪分页
May 25 #PHP
php中iconv函数使用方法
May 24 #PHP
在PHP中使用模板的方法
May 24 #PHP
php读取数据库信息的几种方法
May 24 #PHP
You might like
追忆往昔!浅谈收音机的百年发展历史
2021/03/01 无线电
PHP随机生成随机个数的字母组合示例
2014/01/14 PHP
PHP+redis实现添加处理投票的方法
2015/11/14 PHP
一组JS创建和操作表格的函数集合
2009/05/07 Javascript
用jquery统计子菜单的条数示例代码
2013/10/18 Javascript
js实现ArrayList功能附实例代码
2014/10/29 Javascript
jQuery拖拽插件gridster使用指南
2015/04/21 Javascript
js基础之DOM中document对象的常用属性方法详解
2016/10/28 Javascript
tablesorter.js表格排序使用方法(支持中文排序)
2017/02/10 Javascript
AngularJS中filter的使用实例详解
2017/08/25 Javascript
原生js封装添加class,删除class的实例
2017/11/06 Javascript
浅谈Webpack自动化构建实践指南
2017/12/18 Javascript
从setTimeout看js函数执行过程
2017/12/19 Javascript
vue-better-scroll 的使用实例代码详解
2018/12/03 Javascript
vue结合element-ui使用示例
2019/01/24 Javascript
vue实现滑动超出指定距离回顶部功能
2019/07/31 Javascript
解决layui数据表格table的横向滚动条显示问题
2019/09/04 Javascript
jquery实现简单拖拽效果
2020/07/20 jQuery
详解三种方式在React中解决绑定this的作用域问题并传参
2020/08/18 Javascript
javascript实现前端分页功能
2020/11/26 Javascript
[02:27]2018DOTA2亚洲邀请赛赛前采访-OpTic
2018/04/03 DOTA
[52:20]VP vs VG Supermajor小组赛 B组胜者组决赛 BO3 第一场 6.2
2018/06/03 DOTA
[42:11]TNC vs Pain 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
用Python生成器实现微线程编程的教程
2015/04/13 Python
Python实现的文本简单可逆加密算法示例
2017/05/18 Python
python 创建弹出式菜单的实现代码
2017/07/11 Python
Python实现基于多线程、多用户的FTP服务器与客户端功能完整实例
2017/08/18 Python
Flask框架 CSRF 保护实现方法详解
2019/10/30 Python
波兰最大的电商平台:Allegro.pl
2021/02/06 全球购物
测量实习生自我鉴定
2013/09/19 职场文书
函授本科自我鉴定
2014/02/04 职场文书
2014年三八妇女节活动总结
2014/03/01 职场文书
电子商务助理求职自荐信
2014/04/10 职场文书
股东出资证明书(正规版)
2014/09/24 职场文书
婚前协议书标准版
2014/10/19 职场文书
Python实现Matplotlib,Seaborn动态数据图
2022/05/06 Python