MYSQL的操作类(已封装)

class MySQLDB     {       //MYSQL数据库操作类       //作者:熊毅       //版本:2.0(发行版)       //可以自由转载,修改请通知我scxy78@yeah.net       //转载请保留以上声明       //使用说明:       //该类完全按照ADO的习惯书写的,用过ASP的人都觉得ASP连接数据库比PHP好用(这是我的感觉),       //但PHP得一个一个API地写,挺累,该类做了完全的封装       //创建类的实例时可以指定一个数据库表和选择的数据库,如:new MySQLDB("table","database");       //查询数据时Query后可以用GetValue得到相应的值,既可以是字段名也可以是已0开始的序号       //插入新值,先用AddNew后使用SetValue相应的字段名或序号和字段值,在用Update添加       //编辑时用Edit指定编辑记录的条件在使用SetValue,最后用Update添加       //在类使用过程中,sTName记录上次使用的数据库表名,当指定后可以直接使用,以后的操作默认在该表       //上进行操作,当然也可以每次指定特殊的表进行操作       //nErr指示是否操作出错,sErr记录最后一次出错的错误代码,记录了明确的有哪个函数引起的错误       //错误之处请指正       //欢迎来信与我交流编程经验:scxy78@yeah.net       //我的CSDN:用户号:scxy;呢称:小熊,请多关照       //可以自由转载,修改请通知我scxy78@yeah.net       //转载请保留以上声明    var $host="localhost";        //主机名       var $user="boot";           //用户名       var $password="oaserver";   //用户密码       var $linkid;                 //连接值       var $dbid;                   //数据库选择的结果值       var $sTName;                  //指定当前操作的数据库表       var $sErr;                   //错误代码       var $nErr;                   //指示是否有错误存在,0无错误,1有错误       var $nResult;                //查询结果值       var $aFName;                 //保存FieldsName的数组       var $nRows;                  //查询结果中的行数       var $nCols;                  //查询结果中的列数       var $aNew;                   //添加在AddNew函数后的数据,以数组形式保存       var $NewEdit;                  //判断当前是否在进行添加操作,0表示没有,1表示在进行添加,2表示编辑       var $sEditCon;               //指定编辑记录的条件       var $nOffset;                //记录偏移量       var $EOF;                     //标记是否到记录集尾       var $sSQL;                    //最后一条执行的SQL语句    //执行Update所要用到的全局变量       var $sName;                   //字段名       var $sValue;                  //字段值AddNew时用       var $sEdit;                   //字段值Edit时用    function Initialize()       {         $this->nErr=0;         $this->NewEdit=0;         $this->nResult=-1;         $this->nCols=0;         $this->nRows=0;         $this->nOffset=0;         $this->EOF=true;         $this->sName="";         $this->sValue="#@!";         $this->sEdit="#@!";         unset($this->aFName);         unset($this->aNew);       }       function MySqlDB($TableName="",$database="slt")  //构造函数       {         $this->Initialize();         $this->sTName=$TableName;         $this->linkid=mysql_connect($host,$user,$password);         if(!$this->linkid)         {           $this->nErr=1;           $this->sErr="MySqlDB:数据库连接出错,请启动服务!";           return;         }         $this->dbid=mysql_select_db($database);         if(!$this->dbid)         {           $this->nErr=1;           $this->sErr="MySqlDB:选择的数据库".$database."不存在!";           return;         }       }    function IsEmpty($Value)       {               if(is_string($Value)&&empty($Value))                  return true;               return false;       }    function Destroy()          //数据清除处理       {         mysql_query("commit");         mysql_close();       }    function PrintErr()       {         if($this->nErr==1)         {           echo($this->sErr."<br><br>");         }         else         {           echo("没有错误<br><br>");         }       }        function Execute($SQL)  //直接执行SQL语句             {                   if(empty($SQL))                     {                           $this->nErr=1;                           $this->sErr="Execute:执行语句不能为空!";                           return false;                     }                    $this->sSQL=$SQL;                     if(!mysql_query($SQL))                     {                             $this->nErr=1;                             $this->sErr="Execute:SQL语句:".$SQL."<br>MySql错误:".mysql_error();                             return false;                     }                     return true;             }    function Query($TableName="",$SQL="*",$Condition="",$Order="",$Sequenc="") //在数据库里执行查询       {         $this->Initialize();         if(!empty($TableName))           $this->sTName=$TableName;         $strSQL="select ".$SQL." from ".$this->sTName;         if(!empty($Condition))           $strSQL=$strSQL." where ".$Condition;         if(!empty($Order))           $strSQL=$strSQL." order by ".$Order;         if(!empty($Sequenc))           $strSQL=$strSQL." ".$Sequenc;             $this->sSQL=$strSQL;         if(!$this->nResult=mysql_query($strSQL))         {           $this->nErr=1;           $this->sErr="Query:SQL语句:".$strSQL."<br>MySql错误:".mysql_error()."<br>";           return;         }         $this->nOffset=0;         $this->nRows=mysql_num_rows($this->nResult);         $this->nCols=mysql_num_fields($this->nResult);             if($this->nRows>0)                     $this->EOF=false;             else                     $this->EOF=true;         unset($this->aFName);         $this->aFName=array();         for($i=0;$i<$this->nCols;$i++)            $this->aFName[$i]=strtolower(mysql_field_name($this->nResult,$i));       }        function MoveNext()             {                   if($this->EOF)                     {                           $this->nErr=1;                           $this->sErr="MoveNext:已经移到记录集末尾!";                           return;                     }                   $this->nOffset++;                   if($this->nOffset>=$this->nRows)                           $this->EOF=true;             }     function MoveTo($Offset)        {           if(empty($Offset))           {             $this->nErr=1;             $this->sErr="MoveTo:必须指定偏移量! ";             return;           }        if(!$this->nResult)           {             $this->nErr=1;             $this->sErr="MoveTo:请先执行查询:Query";             return;           }           $this->nOffset=$Offset;        }    //得到指定行的指定列的值,返回字符串       //如果不指定Offset将取得下一行的值       //如果不指定nFields将取得该行的值,并已数组形式返回       function GetValue($nFields=-1,$Offset=-1)       {         if($this->nResult==-1)         {           $this->nErr=1;           $this->sErr="GetValue:请先执行Query()函数!";           return;         }         if($Offset>-1)         {                   $this->nOffset=$Offset;           if($this->nOffset>=$this->nRows)           {             $this->nErr=1;             $this->sErr="GetValue:所要求的偏移量太大,无法达到!";             return;           }         }              if(!@mysql_data_seek($this->nResult,$this->nOffset))                   {                     $this->nErr=1;                     $this->sErr="GetValue:请求不存在的记录!";                     return;                   }         $aResult=mysql_fetch_row($this->nResult);         if(is_int($nFields)&&$nFields>-1)         {           if($nFileds>$this->nCols)           {             $this->nErr=1;             $this->sErr="GetValue:所请求的列值大于实际的列值!";             return;           }           return $aResult[$nFields];         }             if(is_string($nFields))             {                   $nFields=strtolower($nFields);               for($i=0;$i<$this->nCols;$i++)                   {                     if($this->aFName[$i]==$nFields)                             break;                   }                   if($i==$this->nCols)                     {                           $this->nErr=1;                           $this->sErr="GetValue:所请求的列不存在,请仔细检查!";                           return;                     }                     return $aResult[$i];             }         return $aResult;       }    function AddNew($TableName="")  //标志开始添加数据       {         $this->Initialize();         if(!empty($TableName))           $this->sTName=$TableName;         if($this->NewEdit>0)         {           $this->nErr=1;           $this->sErr="AddNew:你正在对数据库进行添加或更新操作!";           return;         }         if(empty($this->sTName))         {           $this->nErr=1;           $this->sErr="AddNew:想要添加的数据库表为空,可以在构造时指定,也可在AddNew()时指定!";           return;         }         unset($this->aNew);         $this->aNew=array();         $this->NewEdit=1;         $strSQL="select * from ".$this->sTName;             $this->sSQL=$strSQL;         if(!$this->nResult=mysql_query($strSQL))         {           $this->nErr=1;           $this->sErr="AddNew:SQL语句:".strSQL."<br><br>MySql错误:".mysql_error();           return;         }         $this->nCols=mysql_num_fields($this->nResult);         unset($this->aFName);         $this->aFName=array();         for($i=0;$i<$this->nCols;$i++)            $this->aFName[$i]=strtolower(mysql_field_name($this->nResult,$i));       }    function Edit($Condition="",$TableName="")  //对指定数据库表进行编辑       {                     $this->Initialize();                     if(!empty($TableName))                             $this->sTName=$TableName;                     $this->sEditCon=$Condition;                     if(empty($this->sTName))                     {                             $this->nErr=1;                             $this->sErr="Edit:在编辑前请先指定数据库表!";                             return;                     }                     unset($this->aNew);                     $this->aNew=array();                     $this->NewEdit=2;                     $strSQL="select * from ".$this->sTName;                     $this->sSQL=$strSQL;                     if(!$this->nResult=mysql_query($strSQL))             {                $this->nErr=1;                $this->sErr="Edit:SQL语句:".strSQL."<br><br>MySql错误:".mysql_error();                return;             }             $this->nCols=mysql_num_fields($this->nResult);             unset($this->aFName);             $this->aFName=array();             for($i=0;$i<$this->nCols;$i++)                $this->aFName[$i]=strtolower(mysql_field_name($this->nResult,$i));       }    function SetValue($Index,$Value) //指定数据,跟在AddNew后执行;       {                if($this->NewEdit==0)                {                   $this->nErr=1;                   $this->sErr="SetValue:请先执行AddNew()或者Edit()!";                   return;                }                if(is_int($Index))                {                    if($Index<0||$Index>$this->nCols)                    {                       $this->nErr=1;                       $this->sErr="SetValue:插入不存在的列值!";                       return;                    }                    $this->aNew[$Index]=$Value;                    $tmpIn=$Index;                }                elseif(is_string($Index))                {                   $Index=strtolower($Index);                   for($i=0;$i<$this->nCols;$i++)                   {                       if($this->aFName[$i]==$Index)                          break;                   }                   if($i==$this->nCols)                   {                       $this->nErr=1;                       $this->sErr="SetValue:插入不存在的列值!";                       return;                    }                    $this->aNew[$i]=$Value;                    $tmpIn=$i;                }                    if(!empty($this->sName))                       $this->sName.=",";                    $this->sName.=$this->aFName[$tmpIn];                    //根据当前字段的类型生成相应的新值                    if($this->sValue!="#@!")                       $this->sValue.=",";                    else                       $this->sValue="";                    $ftype=@mysql_field_type($this->nResult,$i);                    //echo($ftype.",".$this->aNew[$i].",".$i.":".$sValue."<br>");                    switch($ftype)                    {                     case "string":                     case "date":                     case "datetime":                           $this->sValue.="\"".$this->aNew[$tmpIn]."\"";                           $this->sEdit="\"".$this->aNew[$tmpIn]."\"";                           break;                     case "int":                     case "unknown":                          $this->sValue.=$this->aNew[$tmpIn];                          $this->sEdit=$this->aNew[$tmpIn];                          break;                     default:                          $this->nErr=1;                          $this->sErr="Update:字段名为".$this->aFName[$tmpIn]."的".$ftype."类型目前版本不支持,请用别的方法添加数据!";                          return;                    }                 if($this->NewEdit==2)                       $this->sName.="=".$this->sEdit;         }    function Update()    //存储新值到数据库       {         $strSQL="";      if($this->NewEdit==0)         {           $this->nErr=1;           $this->sErr="Update:请先执行AddNew()或者Edit(),再用SetValue()添加值!";           return;         }      if(empty($this->sValue))         {           $this->nErr=1;           $this->sErr="Update:在数据为空的情况下,不能添加或修改数据!";           return;         }      switch($this->NewEdit)         {          case 1:       //添加               $strSQL="insert into ";               $strSQL.=$this->sTName;               $strSQL.=" (".$this->sName.") ";               $strSQL.="values (".$this->sValue.")";               break;         case 2:          //修改               $strSQL="update ";               $strSQL.=$this->sTName;               $strSQL.=" set ";               $strSQL.=$this->sName;               if(!empty($this->sEditCon))                   $strSQL.=" where ".$this->sEditCon;               break;         default:              $this->nErr=1;              $this->sErr="Update:Update()生成SQL语句出错,请检查!";              return;         }      $this->sSQL=$strSQL;         if(!$this->nResult=mysql_query($strSQL))         {           $this->nErr=1;           $this->sErr="Update:SQL语句:".$strSQL."<br><br>MySql错误:".mysql_error();           return;         }          //echo($this->sSQL."<br>");         //作清理工作         $this->NewEdit=0;         unset($this->aNew);         mysql_query("commit");       }     }

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据库
, return
, function
, this
, if
, addnew
, $this
, $(this)
this[]
php操作mysql的封装类、nodejs mysql操作封装、php mysql操作封装、python 操作mysql封装、c mysql封装类,以便于您获取更多的相关知识。

时间: 2024-11-01 09:40:18

MYSQL的操作类(已封装)的相关文章

MYSQL的操作类(修改后的新版本)

mysql           class MySQLDB  {    //MYSQL数据库操作类    //作者:熊毅    //版本:2.0(发行版)        //可以自由转载,修改请通知我scxy78@yeah.net    //转载请保留以上声明        //使用说明:    //该类完全按照ADO的习惯书写的,用过ASP的人都觉得ASP连接数据库比PHP好用(这是我的感觉),    //但PHP得一个一个API地写,挺累,该类做了完全的封装    //创建类的实例时可以指定

简单快速有趣的MySQL数据库操作类:SimpleDB

mysql|数据|数据库 自己写着玩的,代码没有测试,不过觉得思路不错,如果能够加上部分异常处理的功能,应该比较帅了,支持PHP4/PHP5,恩,虽然没有ADOdb或者PEAR::DB强,不错一般应用应该不错,恩. 喜欢的就自己拿去用吧,自己随便改,呵呵,也欢迎提意见.(注释遵循PHPDoc的标准,便于生成手册)  注意:代码未经测试,出现问题可要自己负责哇,呵呵.         <?//==========================================// 文件: Simp

php实现的mysql数据库操作类

 这篇文章主要介绍了php实现的mysql数据库操作类,本文最后有使用方法,需要的朋友可以参考下  代码如下: <?php /* 数据库操作类 */ class Mysql{  private $LocalHost = 'localhost';  private $LoaclUser = 'root';  private $LocalPass = '123456';  private $LocalBase = 'jiangxibaiyi';  private $LocalCode = 'UTF8

php pdo mysql数据库操作类

原文:php pdo mysql数据库操作类   findAll(array( 'field'=>'ID,albumName,albumImage, mainActor,directors,tags,info,area, keywords,wflag,year,mod_version,totalDuration', 'where'=>$where, 'order'=>'flag desc,hit_count desc', 'limit'=>"{$limit['offset

从一个不错的留言本弄的mysql数据库操作类_php技巧

从一个不错的留言本弄的mysql数据库操作类,初学php的朋友可以参考下 复制代码 代码如下: <?php class mysql{     var $querynum = 0;     function connect($dbhost, $dbuser, $dbpw, $dbname = '',$dbcharset='') {         if(!@mysql_connect($dbhost, $dbuser, $dbpw)) {             $this->show('Can

PHP实现PDO的mysql数据库操作类_php技巧

本文实例讲述了PHP实现PDO的mysql数据库操作类.分享给大家供大家参考.具体分析如下: dbconfig类负责配置数据库访问信息,包括:服务器地址.端口.数据库实例名.用户名.用户密码.字符集等. dbtemplate类集合了对数据库的访问操作,主要有以下几个操作: 1. queryrows:返回多行记录 2. queryrow:返回为单条记录 3. queryforint:查询单字段,返回整数 4. queryforfloat:查询单字段,返回浮点数(float) 5. queryfor

mysql PDO 操作类的例子

介绍: 1.只有在执行select.update.delete.insert等操作时才会连接数据库 2.采用PDO预处理方式 3.事务处理 4.错误输出    代码如下 复制代码 <?php /**  * mysql PDO 操作类  * Created by PhpStorm.  * User: sumiaowen  * Date: 14-3-12  * Time: 下午4:57  * To change this template use File | Settings | File Tem

一个ASP.NET的MYSQL的数据库操作类自己封装的_实用技巧

/** * 类说明:对MYSQL数据库的操作类 */ using System; using System.Data; using MySql.Data.MySqlClient; namespace Niunan.BYLW.Utility { /// <summary>对MYSQL数据库的操作类 /// /// </summary> public class MYSQLHelper { private MySqlConnection conn = null; private MyS

支持php4、php5的mysql数据库操作类_php技巧

前端一直使用PHP5,的确使用起来特别的爽,现在为了能在俺的虚拟主机上跑,不得不改成PHP4的.这几个库类我以前发在PHPCHIAN,地址是http://www.phpchina.com/bbs/viewthread.php?tid=5687&highlight=.(前几天在网上搜索了下,发现很多转载我的这几篇文章都没有说明出处,而且把我的版权都删除了,气晕了.)     昨天改写了数据库操作类,恰好在我简化zend Framework也能用到.     代码如下: <?php /** *