PHP中通过ADO调用Access数据库的方法测试不通过


Posted in PHP onDecember 31, 2006

我看了那篇《怎样在PHP中通过ADO调用Asscess数据库和COM程序》文章后,马上作了测试,结果失败了。伤心是不是。 

怎么办?我只好去PHP官方网站求助,皇天不负有心人,终于我找到了答案—— 

具体的解决方法如下: 
(1)下载相应的ZIP包;同MICROSOFT公司的ADO一样,该东东用PHP实现ADO同各种各样数据库打交道(太好了,所有类型的数据库都能处理)。
(2)解包,里面文件很多,不过有用的只有ohtml.inc.php和adodb.inc.php,(经我测试并不是这样)把它们复制到相应目录下(或是安装php4的缺省目录下c:\php4\peer\,或是当前运行程序目录下,视include()函数而定);
(3)然后在本机的c:\myphp目录下(iis下设置通过http://localhost/jhk来访问),造了一个名为test.mdb的access库,里头再造个experts的表……。为了通过DSN来访问,我把刚才的ACCESS库在DSN中取名test。 
(4)运行。看着说明书我造了这么个程序: 
dbtest.php,内容如下:

<?php  
include('tohtml.inc.php'); // load code common to ADODB   
include('adodb.inc.php'); // load code common to ADODB   
$conn = &ADONewConnection('access'); // create a connection   
$conn->PConnect('test');// connect to MySQL, agora db   
$sql = 'select name, group1 from experts';   
$rs = $conn->Execute($sql);   
rs2html($rs,'border=2 cellpadding=3',array('Customer Name','Customer ID'));   
$rs->Close(); // optional   
$conn->Close(); // optional   
?>  

然后,IE中打入:http://localhost/jhk/dbtest.php 
唉!结果出来了。 令人基本满意!! 

(5) 接着,我又想:还要设置DSN,烦不烦!绕过DSN应如何解决?因为在asp中,我习惯用conn.open("provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.Mappath("../nydatabase.mdb"))来处理mdb库,那速度快呀! 
?……想了又想,看了又看……。 

找找找,……,嘿嘿,终于在testdatabases.inc.php 中找到了答案! 我再把刚才的程序改编: 

<?php   
include('tohtml.inc.php'); // load code common to ADODB   
include('adodb.inc.php'); // load code common to ADODB   
$db = &ADONewConnection("ado_access");   
print "<h1>Connecting $db->databaseType...</h1>";   
$access = 'test.mdb';   
$myDSN = 'PROVIDER=Microsoft.Jet.OLEDB.4.0;'.'DATA SOURCE='. $access . ';';.'USER ID=;PASSWORD=;';   if (@$db->PConnect($myDSN, "", "", "")) {   
print "ADO version=".$db->_connectionID->version."  
";   
$sql = 'select name, group1 from experts';   
$rs = $db->Execute($sql);   
rs2html($rs,'border=2 cellpadding=3',array('Customer Name','Customer ID'));   
} else print "ERROR: Access test requires a Access database $access".'  
'.$db->ErrorMsg();   
?>  

运行。 
一切搞定!(经我测试实际上并不能解决问题),大家可以看下一篇,就知道了

PHP 相关文章推荐
WordPress判断用户是否登录的代码
Mar 17 PHP
php Rename 更改文件、文件夹名称
May 24 PHP
php 调试利器debug_print_backtrace()
Jul 23 PHP
php时间戳转换的示例
Mar 31 PHP
php的mkdir()函数创建文件夹比较安全的权限设置方法
Jul 28 PHP
PHP实现抓取Google IP并自动修改hosts文件
Feb 12 PHP
laravel 5 实现模板主题功能(续)
Mar 02 PHP
PHP贪婪算法解决0-1背包问题实例分析
Mar 23 PHP
学习php设计模式 php实现原型模式(prototype)
Dec 07 PHP
PHP读取大文件的多种方法介绍
Apr 04 PHP
Yii框架防止sql注入,xss攻击与csrf攻击的方法
Oct 18 PHP
浅谈PHP中的错误处理和异常处理
Feb 04 PHP
刚才在简化php的库,结果发现很多东西
Dec 31 #PHP
smarty+adodb+部分自定义类的php开发模式
Dec 31 #PHP
adodb与adodb_lite之比较
Dec 31 #PHP
PHP获得用户使用的代理服务器ip即真实ip
Dec 31 #PHP
使用adodb lite解决问题
Dec 31 #PHP
PHP通过COM使用ADODB的简单例子
Dec 31 #PHP
Adodb的十个实例(清晰版)
Dec 31 #PHP
You might like
php str_pad 函数使用详解
2009/01/13 PHP
php cookies中删除的一般赋值方法
2011/05/07 PHP
PHP spl_autoload_register实现自动加载研究
2011/12/06 PHP
php计算十二星座的函数代码
2012/08/21 PHP
关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况
2013/01/06 PHP
PHP删除指定目录中的所有目录及文件的方法
2015/02/26 PHP
标准版Eclipse搭建PHP环境的详细步骤
2015/11/18 PHP
js压缩工具 yuicompressor 使用教程
2010/03/31 Javascript
js关闭子窗体刷新父窗体实现方法
2012/12/04 Javascript
自动设置iframe大小的jQuery代码
2013/09/11 Javascript
jQuery xml字符串的解析、读取及查找方法
2016/03/01 Javascript
thinkjs之页面跳转同步异步操作
2017/02/05 Javascript
jQuery EasyUI ProgressBar进度条组件
2017/02/28 Javascript
原生js实现3D轮播图
2020/03/21 Javascript
vue移动端的左右滑动事件详解
2020/06/17 Javascript
js实现简单的轮播图效果
2020/12/13 Javascript
Python实现的监测服务器硬盘使用率脚本分享
2014/11/07 Python
Python判断值是否在list或set中的性能对比分析
2016/04/16 Python
使用python在本地电脑上快速处理数据
2017/06/22 Python
python 读写excel文件操作示例【附源码下载】
2019/06/19 Python
Python序列对象与String类型内置方法详解
2019/10/22 Python
pygame实现成语填空游戏
2019/10/29 Python
8段用于数据清洗Python代码(小结)
2019/10/31 Python
wxPython实现画图板
2020/08/27 Python
python实现画出e指数函数的图像
2019/11/21 Python
Numpy 多维数据数组的实现
2020/06/18 Python
英国最大的百货公司:Harrods
2016/08/18 全球购物
京东港澳售:京东直邮港澳台
2018/01/31 全球购物
一些网络技术方面的面试题
2014/05/01 面试题
会计电算化学生个人的自我评价
2014/02/08 职场文书
二年级评语大全
2014/04/23 职场文书
爱心倡议书范文
2014/05/12 职场文书
三年级学生期末评语
2014/12/26 职场文书
少先大队干部竞选稿
2015/11/20 职场文书
浅谈react useEffect闭包的坑
2021/06/08 Javascript
聊聊Python String型列表求最值的问题
2022/01/18 Python