我的php的一个数据库的操纵类

原创 2004年04月05日 23:34:00

以下是我在工作中常用的一个php中对sql server2000中数据操纵的一个公共odbc操纵类,希望能够给各位初学php的同仁一点点帮助

<?
file://include ("odbc_para.php");
$DbName="localhost";
$DbUser="sa";
$DbPassWord="";//在这里进行定义连接odbc的数据库名,用户名,及密码,实际中以数据库的用户

file://名及密码为标准。

define(C_DB_HOST,$Host);
define(C_DB_NAME,$DbName);
define(C_DB_USER,$DbUser);
define(C_DB_PASS,$DbPassWord);

class Odbc{
    var $Host = C_DB_HOST;   // Hostname of our MySQL server
    var $Database = C_DB_NAME;  // Logical database name on that server
    var $User = C_DB_USER;   // Database user
    var $Password = C_DB_PASS;  // Database user's password
    var $UseODBCCursor = 0;

    var $Link_ID = 0;    // Result of mysql_connect()
    var $Query_ID = 0;    // Result of most recent mysql_query()
    // var $Record = array();                      // Current mysql_fetch_array()-result
    var $Row    = 0;     // Current row number
    var $Errno = 0;     // Error state of query
    var $Error = "";

  var $Auto_Free = 0;     ## set this to 1 to automatically free results


function Halt($msg) {
    printf("</td></tr></table><b>Database error:</b> %s<br>/n", $msg);
    printf("<b>ODBC Error</b>: %s (%s)<br>/n",
      $this->Errno,
      $this->Error);
    die("Session halted.");
  }


function Connect() {
    if ( 0 == $this->Link_ID ) {
      $this->Link_ID=odbc_connect($this->Database, $this->User, $this->Password, $this->UseODBCCursor);
      if (!$this->Link_ID) {
        $this->halt("Link-ID == false, odbc_connect failed");
      }
    }
  }
 
function Close() {
 if (0 != $this->Link_ID){
  odbc_close($this->Link_ID);
 }
}

function Query($Query_String) {
    $this->Connect();
   
#   printf("<br>Debug: query = %s<br>/n", $Query_String);

#   rei@netone.com.br suggested that we use this instead of the odbc_exec().
#   He is on NT, connecting to a Unix MySQL server with ODBC. -- KK
#    $this->Query_ID = odbc_prepare($this->Link_ID,$Query_String);
#    $this->Query_Ok = odbc_execute($this->Query_ID);
       
    $this->Query_ID = odbc_exec($this->Link_ID,$Query_String);
    $this->Row = 0;
    file://odbc_binmode($this->Query_ID, 1);
    file://odbc_longreadlen($this->Query_ID, 4096000);
   
    if (!$this->Query_ID) {
      $this->Errno = 1;
      $this->Error = "General Error (The ODBC interface cannot return detailed error messages).";
      $this->halt("Invalid SQL: ".$Query_String);
    }
    return $this->Query_ID;
  }
 
function NextRecord() {
    $this->Record = array();
    $this->$stat = odbc_fetch_into($this->Query_ID,&$this->Record, ++$this->Row);
    if (!$this->$stat) {
      if ($this->Auto_Free) {
 odbc_free_result($this->Query_ID);
        $this->Query_ID = 0;
 };
    } else {
      // add to Record[<key>]
      $count = odbc_num_fields($this->Query_ID);
      for ($i=1; $i<=$count; $i++)
        $this->Record[strtolower(odbc_field_name ($this->Query_ID, $i)) ] = stripslashes($this->Record[ $i - 1 ]);
    }
    return $this->Record;
  }
 
function Seek($pos) {
    $this->Row = $pos;
  }

function MetaData($table) {
    $count = 0;
    $id    = 0;
    $res   = array();

    $this->Connect();
    $id = odbc_exec($this->Link_ID, "select * form $table");
    if (!$id) {
      $this->Errno = 1;
      $this->Error = "General Error (The ODBC interface cannot return detailed error messages).";
      $this->halt("Metadata query failed.");
    }
    $count = odbc_num_fields($id);
   
    for ($i=1; $i<=$count; $i++) {
      $res[$i]["table"] = $table;
      $name             = odbc_field_name ($id, $i);
      $res[$i]["name"]  = $name;
      $res[$i]["type"]  = odbc_field_type ($id, $name);
      $res[$i]["len"]   = 0;  // can we determine the width of this column?
      $res[$i]["flags"] = ""; // any optional flags to report?
    }
   
    odbc_free_result($id);
    return $res;
  }
 


function NumRows() {
    # Many ODBC drivers don't support odbc_num_rows() on SELECT statements.
    $num_rows = odbc_num_rows($this->Query_ID);
 file://printf ($num_rows."<br>");

    # This is a workaround. It is intended to be ugly.
    if ($num_rows < 0) {
      $i=10;
      while (odbc_fetch_row($this->Query_ID, $i))
        $i*=10;

      $j=0;
      while ($i!=$j) {
        $k= $j+intval(($i-$j)/2);
        if (odbc_fetch_row($this->Query_ID, $k))
          $j=$k;
        else
          $i=$k;
        if (($i-$j)==1) {
          if (odbc_fetch_row($this->Query_ID, $i))
            $j=$i;
          else
            $i=$j;
        };
        file://printf("$i $j $k <br>");
      };
      $num_rows=$i;
    }

    return $num_rows;
  }
 

function NumFields() {
    return count($this->Record)/2;
  }
 
function FieldValue($Field_Name){
    return odbc_result($this->Query_ID,$Field_Name);//Record[strtolower($Field_Name)];
  }
 
function AffectedRows() {
    return odbc_num_rows($this->Query_ID);
  } 


}
?>

我的这个操作类是一个odbc接口类。在调用数据操作之前首先需进行odbc的连接,然后再把相应的值付给下面的变量,以便进行操纵:

$DbName="localhost";
$DbUser="sa";
$DbPassWord="";//

假设在odbc连接成功的条件下,对数据库中的表table1进行操作则如下进行:

$db=new Odbc();

$sq1="select * from $table";//选择表中的所有记录

$db->query($sql);

while($result=$db->NextRecrod)

{

echo $result;

}

$db->Close();

.

.

.

 

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

使用过ThinkPHP框架的同学可能会对于其中数据库模型操作特别有好感,ThinkPHP提供了数据库操作的简单的操作,对于连接数据库,数据库的增删改查等数据操作都非常的nice,同时支持连贯操作,对于...
  • helencoder
  • helencoder
  • 2016年04月17日 11:27
  • 12304

Oracle数据操作和控制语言详解

对于SQL语言,有两个组成部分:DML、DDL DML(data manipulation language):它们是SELECT、UPDATE、INSERT、DELETE,就象它的名字一样,这4条...
  • jackpk
  • jackpk
  • 2013年04月17日 07:58
  • 2424

PHP操作mysql类的封装

版本一:
  • qq_15096707
  • qq_15096707
  • 2016年03月02日 11:11
  • 2389

自己写的一个PHP数据库操作类

  • 2014年09月08日 14:06
  • 2KB
  • 下载

自己写的一个PHP MYSQL数据库的处理类

  • 2011年09月14日 13:57
  • 4KB
  • 下载

一个普遍通用的PHP连接MYSQL数据库类

  • 2012年03月02日 08:57
  • 52KB
  • 下载

一个PHP在线备份和恢复MySQL数据库的类

  • weizhimiao
  • weizhimiao
  • 2014年04月16日 13:42
  • 585

一个关于php使用pdo方式进行数据库连接和处理的类

话不多说,先贴代码
  • meeeen7
  • meeeen7
  • 2016年08月06日 15:24
  • 2737

写的一个简简单单的php数据库调用类和调用例子.

  • u011773814
  • u011773814
  • 2014年07月22日 10:59
  • 514

PHP用单例模式实现一个数据库类

使用单例模式的出发点:     1、php的应用主要在于数据库应用, 所以一个应用中会存在大量的数据库操作, 使用单例模式, 则可以避免大量的new 操作消耗的资源。   2、如果系统中需要有一个...
  • gb4215287
  • gb4215287
  • 2017年12月11日 00:52
  • 32
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:我的php的一个数据库的操纵类
举报原因:
原因补充:

(最多只允许输入30个字)