当前位置: 首页 > 图文教程 > 网络编程 > PHP > 用php+odbc+access数据库来操作函数

PHP
书评: PHP和ORACLE基础手册
最小化数据传输――在客户端存储数据
玩转虚拟域名◎+
DOMXML: Expat之外的另一选择
SQLite数据库安全
fckeditor用javascript创建
phplib7.2中文汉化版及调用示例
SQLite语法备忘录
将Oracle 10g内置的安全特性用于PHP
PHP5 & Web Services 系统架构图
解决PHP startup: Unable to load dynamic library的错误
PHP and Web Services
深入研究表单提交方式:GET/POST
php5中XML-RPC函数的使用
一 php与XML、XSLT、Mysql的结合运用,安装篇
二 php与XML、XSLT、Mysql的结合运用,代码篇
设计模式汇总
PHP5的异常处理机制
使用PHP5创建图形巧法(一)
使用PHP5创建图形巧妙方法(二)

PHP 中的 用php+odbc+access数据库来操作函数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 122 ::
收藏到网摘: n/a

前些天下载了adodb,想用adodb连access数据库,后来连是连上了,不过不能更新和插入记录,也不知道为什么到现在还没人给我回答那个苦恼的问题,后来就放弃了adodb,使用php自己的odbc,但是使用很不方便,就写下了下面这些函数,还没有封装成类,希望能够为有同样问题的朋友一些帮助 。

 <?php
  /*
   * @ access class
   * insert,update,delete record
   * version 1.0
   * date 2005.6
   * power by Samsun Manzalo (34n 猪八戒)
   *
   */
  
  //====================================
  // insert record
  // 插入记录
  //====================================
  function insRd( table, field){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    tmpA = explode(',', field);
    ins = '';
   for( i=0; i<count( tmpA); i++){
    ins.= "'". _POST[ tmpA[ i]]."',";
   }
    ins = substr( ins,0,-1);
    sql = "INSERT INTO ". table." (". field.") VALUES (". ins.")";
   //echo  sql;exit;
    query = @odbc_do( connid, sql);
  }
  
  
  //====================================
  // get one record detail
  // 取得当条记录详细信息
  //====================================
  function getInfo( table, field, id, colnum){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "select * from ". table." where ". field."=". id;
    query = @odbc_do( connid, sql);
  
   if(odbc_fetch_row( query)){
   for( i=0; i< colnum; i++){
    info[ i] = odbc_result( query, i+1);
   }
   }
   return  info;
  }
  
  
  //====================================
  // get record list
  // 取得记录列表
  //====================================
  function getList( table, field, colnum, condition, sort="order by id desc"){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "select * from ". table." ". condition." ". sort;
    query = @odbc_do( connid, sql);
   //echo  sql."<br>";
    i = 0;
   while(odbc_fetch_row( query)){
    rdList[ i] = getInfo( table, field,odbc_result( query,1), colnum);
    i++;
   }
   return  rdList;
  }
  
  
  //====================================
  // get record list condition
  // 取得记录列表
  //====================================
  function getFieldList( table, field, fieldnum, condition="", sort=""){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "select ". field." from ". table." ". condition." ". sort;
    query = @odbc_do( connid, sql);
   //echo  sql."<br>";
    i = 0;
   while(odbc_fetch_row( query)){
   for( j=0; j< fieldnum; j++){
    info[ j] = odbc_result( query, j+1);
   }
    rdList[ i] =  info;
    i++;
   }
   return  rdList;
  }
  
  //====================================
  // update record
  // 更新记录
  //====================================
  function updateInfo( table, field, id, set){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "update ". table." set ". set." where ". field."=". id;
    query = @odbc_do( connid, sql);
  }
  
  
  //====================================
  // record delete
  // 删除记录
  //====================================
  function delRd( table, field, id){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "delete from ". table." where ". field."=". id;
    query = @odbc_do( connid, sql);
  }
  
  
  //====================================
  // record delete cat
  // 删除记录(条件)
  //====================================
  function delOrRd( table, condition){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "delete from ". table." where ". condition;
    query = @odbc_do( connid, sql);
  }
  
  
  //====================================
  // count record
  // 取得记录数
  //====================================
  function countRd( table, condition=""){
    connstr = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=database/email.mdb";
    connid = @odbc_connect( connstr,"","",SQL_CUR_USE_ODBC ) or die ("数据库连接错误!");
    sql = "select count(*) as num from ". table." ". condition;
    query = @odbc_do( connid, sql);
   odbc_fetch_row( query);
    num = odbc_result( query,1);
   return  num;
  }
  
  ?>